Github標星28K+!這款視覺化的物件儲存服務真香!

MacroZheng發表於2021-08-11

SpringBoot實戰電商專案mall(50k+star)地址:github.com/macrozheng/…

摘要

在我們平時做專案的時候,檔案儲存是個很常見的需求。這時候我們就會用到物件儲存服務,平時我們可能會選擇OSS、AWS S3這類第三方服務。今天帶大家搭建一款自己的物件儲存服務,帶視覺化管理,用起來也挺簡單!

MinIO簡介

MinIO 是一款基於Go語言的高效能物件儲存服務,在Github上已有28K+Star。它採用了Apache License v2.0開源協議,非常適合於儲存大容量非結構化的資料,例如圖片、視訊、日誌檔案、備份資料和容器/虛擬機器映象等。

安裝

使用Docker安裝MinIO服務非常簡單,幾個命令就可以搞定!

  • 首先下載MinIO的Docker映象;
docker pull minio/minio
複製程式碼
  • 下載完成後使用如下命令執行MinIO服務,注意使用--console-address指定MinIO Console的執行埠(否則會隨機埠執行):
docker run -p 9090:9000 -p 9001:9001 --name minio \
-v /mydata/minio/data:/data \
-e MINIO_ROOT_USER=minioadmin \
-e MINIO_ROOT_PASSWORD=minioadmin \
-d minio/minio server /data --console-address ":9001"
複製程式碼
  • 執行成功後就可訪問MinIO Console的管理介面了,輸入賬號密碼minioadmin:minioadmin即可登入,訪問地址:http://192.168.7.142:9090

MinIO Console使用

MinIO Console是MinIO自帶的視覺化管理工具,比起上一代的視覺化工具功能還是強大了不少的,下面我們來體驗下這個工具。

  • 先來看下上一代的MinIO Browser,基本只支援儲存桶及檔案的管理功能;

  • 再來看下MinIO Console,不僅支援了儲存桶、檔案的管理,還增加了使用者、許可權、日誌等管理功能,強了不少;

  • 在儲存檔案之前,我們首先得建立一個儲存桶;

  • 建立成功後,再上傳一個檔案;

  • 上傳成功後如果你想從外部訪問檔案的話,需要把訪問策略設定為公開,這裡的策略只有公開和私有兩種,感覺不太靈活;

客戶端使用

其實對於物件儲存來說,MinIO Console的功能還是不夠用的,所以官方還提供了基於命令列的客戶端MinIO Client(簡稱mc),下面我們來講講它的使用方法。

常用命令

我們先來熟悉下mc的命令,這些命令和Linux中的命令有很多相似之處。

命令作用
ls列出檔案和資料夾
mb建立一個儲存桶或一個資料夾
rb刪除一個儲存桶或一個資料夾
cat顯示檔案和物件內容
pipe將一個STDIN重定向到一個物件或者檔案或者STDOUT
share生成用於共享的URL
cp拷貝檔案和物件
mirror給儲存桶和資料夾做映象
find基於引數查詢檔案
diff對兩個資料夾或者儲存桶比較差異
rm刪除檔案和物件
events管理物件通知
watch監聽檔案和物件的事件
policy管理訪問策略
session為cp命令管理儲存的會話
config管理mc配置檔案
update檢查軟體更新
version輸出版本資訊

安裝及配置

由於MinIO服務端中並沒有自帶客戶端,所以我們需要安裝並配置完客戶端後才能使用,這裡以Docker環境下的安裝為例。

  • 下載MinIO Client 的Docker映象;
docker pull minio/mc
複製程式碼
  • 在Docker容器中執行mc;
docker run -it --entrypoint=/bin/sh minio/mc
複製程式碼
  • 執行完成後我們需要進行配置,將我們自己的MinIO服務配置到客戶端上去,配置的格式如下;
mc config host add <ALIAS> <YOUR-S3-ENDPOINT> <YOUR-ACCESS-KEY> <YOUR-SECRET-KEY>
複製程式碼
  • 對於我們的MinIO服務可以這樣配置。
mc config host add minio http://192.168.7.142:9090 minioadmin minioadmin
複製程式碼

常用操作

  • 檢視儲存桶和檢視儲存桶中存在的檔案;
# 檢視儲存桶
mc ls minio
# 檢視儲存桶中存在的檔案
mc ls minio/blog
複製程式碼

  • 建立一個名為test的儲存桶;
mc mb minio/test
複製程式碼

  • 共享avatar.png檔案的下載路徑;
mc share download minio/blog/avatar.png
複製程式碼

  • 查詢blog儲存桶中的png檔案;
mc find minio/blog --name "*.png"
複製程式碼

  • 設定test儲存桶的訪問許可權為只讀
# 目前可以設定這四種許可權:none, download, upload, public
mc policy set download minio/test/
# 檢視儲存桶當前許可權
mc policy list minio/test/
複製程式碼

相容AWS S3

當我們對接第三方服務要用到物件儲存時,這些服務往往都是支援AWS S3的。比如說一個直播的回放功能,需要物件儲存來儲存回放的視訊,由於MinIO相容AWS S3的大多數API,我們可以直接拿它當AWS S3來使用。

  • 我們可以下載個AWS S3的客戶端來試試,MinIO到底能不能支援S3的API,這裡使用的是S3 Browser,下載地址:s3browser.com/

  • 安裝好S3 Browser之後,新增一個Account,輸入相關登入資訊,注意選擇Account型別為S3 Compatible Storage

  • 連線成功後,我們可以看見之前我們建立的儲存桶和上傳的檔案;

  • S3 Browser這個工具功能還是很強大的,MinIO Console和它比起來實在太弱了;

  • 上面有提到一個問題,圖片檔案無法直接檢視,其實是因為訪問圖片檔案時,MinIO返回的Content-Type為application/octet-stream導致的;

  • 接下來我們可以通過S3 Browser來修改預設返回的響應頭;

  • 然後將.png開頭的檔案的響應頭改為image/png就可以了;

  • 需要注意的是之前上傳的檔案需要重新上傳下才可以生效,此時訪問連結就可以直接檢視圖片了;

  • 如果你想修改儲存桶的訪問許可權的話直接通過Permissions標籤修改即可,是不是比MinIO Console靈活多了。

總結

如果你想自建物件儲存服務的話,MinIO確實是首選。它能相容AWS S3的API,使用MinIO相當於是在使用AWS S3,能相容一些主流的第三方服務。不過它自帶的客戶端MinIO Console確實有點雞肋,還好支援了AWS S3,可以使用一些功能強大的S3客戶端工具。

參考資料

官方文件:docs.min.io/

本文 GitHub github.com/macrozheng/… 已經收錄,歡迎大家Star!

相關文章