Minio 分布式集群安裝配置

目錄創建

mkdir -p /opt/minio/run && mkdir -p /etc/minio && mkdir -p /indata/disk_0/minio/data
  • run:啟動腳本及二進制文件目錄
  • /etc/minio:配置文件目錄
  • data:數據存儲目錄

下載 minio

wget https://dl.min.io/server/minio/release/linux-amd64/minio -P /opt/minio/run/

配置啟動文件

vi /opt/minio/run/run.sh
#!/bin/bash
export MINIO_ROOT_USER=Minio
export MINIO_ROOT_PASSWORD=Test1234!
/opt/minio/run/minio server --config-dir /etc/minio --address ":9000" --console-address ":9001" \
http://192.168.1.1/indata/disk_0/minio/data \
http://192.168.1.2/indata/disk_0/minio/data \
http://192.168.1.3/indata/disk_0/minio/data
  • MINIO_ROOT_USER : 用戶名,長度最小是5個字符 (對應棄用配置: MINIO_ACCESS_KEY)
  • MINIO_ROOT_PASSWORD : 密碼,密碼不能設置過于簡單,不然minio會啟動失敗,長度最小是8個字符 (對應棄用配置: MINIO_SECRET_KEY)
  • –config-dir :指定集群配置文件目錄
  • 這里的用戶名和密碼既可以作為頁面的登錄用戶密碼,也可以作為連接 s3a 文件的密鑰
  • –address “:9000” : 后端 API 服務監聽的網絡地址,: 表示監聽所有可用的網絡接口(即服務器上的所有 IP 地址);9000 是默認的 API 端口號
  • –console-address “:9001” : 該參數指定 MinIO 內置管理控制臺(Web UI)監聽的網絡地址;同樣使用 : 表示監聽所有網絡接口;9001 是默認的控制臺端口號

如果使用棄用的 MINIO_ACCESS_KEY 和 MINIO_SECRET_KEY 則會有告警:

INFO: WARNING: MINIO_ACCESS_KEY and MINIO_SECRET_KEY are deprecated. Please use MINIO_ROOT_USER and MINIO_ROOT_PASSWORD

如果服務器配置了代理(如 clash代理),則可能會導致啟動失敗,需要在 run.sh 中添加(啟動命令前):

unset http_proxy
unset https_proxy

這樣就可以在啟動 minio 時不走代理地址了~

配置為系統服務

vi /usr/lib/systemd/system/minio.service

[Unit]
Description=Minio service
Documentation=https://docs.minio.io/[Service]
WorkingDirectory=/indata/disk_0/minio/data
ExecStart=/opt/minio/run/run.shRestart=on-failure
RestartSec=5[Install]
WantedBy=multi-user.target

注意:這里的路徑要和前面的配置一致

啟動集群

systemctl daemon-reload
systemctl enable minio && systemctl restart minio
systemctl status minio

每個節點均返回如下結果則代表成功

可以通過查看端口進程進一步確認

這種方式返回的啟動日志可能不是很全,可以直接運行腳本查看更完整的日志

可以看到第一個啟動的節點會一直等待其他節點連接成功。

Web UI

瀏覽器輸入集群任意節點地址+9001 (輸入9000會自動跳轉到9001)端口,即可訪問minio:
http://192.168.1.1:9001/
http://192.168.1.2:9001/
http://192.168.1.3:9001/

登錄

創建Bucket

上傳文件


創建密鑰


保存密鑰

"accessKey":"uBoubbhrhXhfw8iQhfMc"
"secretKey":"S6N7xkZme3wGHgd3Y6kKSpqKnYAQRkPfyPWR7Lo7"

Nginx 代理

  • 負載均衡:將客戶端請求平均分配到各個 MinIO 節點
  • 統一入口:客戶端只需知道 Nginx 服務器地址,無需關心后端具體節點

安裝 Nginx 并啟動

yum install -y nginx
systemctl enable nginx && systemctl restart nginx && systemctl status nginx

配置代理

vi /etc/nginx/conf.d/minio.conf
upstream minio_web{server 192.168.1.1:9001;server 192.168.1.2:9001;server 192.168.1.3:9001;
} server {listen       80;listen       [::]:80;server_name  _;location / {proxy_pass http://minio_web;proxy_set_header Host $http_host;client_max_body_size 1000m;}
}
  • 僅需代理 Web UI 端口即可
  • 簡化訪問:使用 80 端口(默認 HTTP 端口)訪問 API 服務,無需指定端口
  • 也可以根據實際情況代理為其他端口

重啟 Nginx

systemctl restart nginx        

測試代理訪問地址

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/92450.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/92450.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/92450.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Spring Boot + ShardingSphere 實現分庫分表 + 讀寫分離實戰

🚀 Spring Boot ShardingSphere 實現分庫分表 讀寫分離(涵蓋99%真實場景) 🏷? 標簽:ShardingSphere、分庫分表、讀寫分離、MySQL 主從、Spring Boot 實戰 分庫分表 vs 讀寫分離 vs 主從配置與數據庫高可用架構區別 …

將普通用戶添加到 Docker 用戶組

這樣可以避免每次使用 Docker 命令時都需要 sudo。以下是具體步驟:1. 創建 Docker 用戶組(如果尚未存在) 默認情況下,安裝 Docker 時會自動創建 docker 用戶組。可以通過以下命令檢查: groupadd docker(如果…

Scrapy(一):輕松爬取圖片網站內容?

目錄 一、CrawlSpider 簡介? 二、實戰案例:圖片網站爬取? 三、代碼解析:核心組件詳解? 類定義: 2.核心屬性:? 3.爬取規則(Rules):? 4.數據提取方法(parse_item)…

使用 systemd 的原生功能來實現 Redis 的自動監控和重啟,而不是依賴額外的腳本最佳實踐方案

使用 systemd 的原生功能來實現 Redis 的自動監控和重啟,而不是依賴額外的腳本最佳實踐方案方案 1:配置 systemd 服務文件(推薦)1. 檢查/創建 Redis 的 systemd 服務文件2. 配置關鍵參數(覆蓋配置示例)3. 重…

Eclipse 代碼模板

Eclipse 代碼模板 引言 Eclipse 作為一款功能強大的集成開發環境(IDE),深受廣大開發者的喜愛。在編程過程中,使用代碼模板可以大大提高開發效率,減少重復勞動。本文將詳細介紹 Eclipse 代碼模板的配置、使用方法以及一…

輸電線路防外破聲光預警裝置 | 防山火/防釣魚/防施工安全警示系統

在輸電網絡的安全保障中,外力破壞是一個不容忽視的問題,各類隱患可能對電力系統造成嚴重影響。TLKS-PMG-WP 輸電線路聲光防外破警示裝置在應對這類挑戰時,有著獨特的技術表現,下面從功能和技術參數兩方面進行詳細介紹。核心功能解…

STM32——STM32CubeMX

總:STM32——學習總綱 一、簡介 注意,非邏輯代碼。 可兼容不同系列的STM32Cube固件包。 STM32Cube前置知識鏈接: STM32——HAL庫 不可過多依賴,此工具只針對STM32芯片,類似英飛凌芯片無法配置。主要用于參考。 二、安…

Java NIO 核心原理與秋招高頻面試題解析

一、NIO 概述Java NIO(New I/O 或 Non-blocking I/O)是 Java 1.4 引入的一套全新 I/O API,位于 java.nio 包下。NIO 提供了與傳統 BIO(Blocking I/O)完全不同的 I/O 處理方式,通過非阻塞模式、緩沖區&#…

vue3+element-plus,el-popover實現篩選彈窗的方法

實現一個篩選框,點擊篩選按鈕出現彈窗,彈窗內有選擇框/輸入框/單選框等等,底部有重置/確定兩個按鈕。需求:點擊篩選外部其他位置可以關閉彈窗,關閉彈窗后已編輯的數據不保存,點擊確定按鈕關閉彈窗&#xff…

python每日一題 貪心算法練習

在一條環路上有 n 個加油站,其中第 i 個加油站有汽油 gas[i] 升。你有一輛油箱容量無限的的汽車,從第 i 個加油站開往第 i1 個加油站需要消耗汽油 cost[i] 升。你從其中的一個加油站出發,開始時油箱為空。給定兩個整數數組 gas 和 cost &…

Python + Pika RabbitMQ集群壓測完整方案

一、最近搭建了個rabbitmq集群 三個磁盤節點,上生產環境之前想做個壓測,測試下穩定性,參考Deepseek做了如下測試方案二、核心代碼實現: 配置文件 (config.py) import os RABBITMQ_NODES [amqp://admin:123456192.168.0.175:8101,…

【第7話:相機模型3】自動駕駛IPM圖像投影拼接技術詳解及代碼示例

IPM圖像投影拼接技術詳解 IPM(逆透視映射)圖像投影拼接技術是一種在計算機視覺中廣泛應用的圖像處理方法,主要用于將多個透視視圖的圖像轉換為鳥瞰視圖并拼接成一個無縫的大場景圖像。該技術特別適用于自動駕駛、機器人導航和監控系統等領域&…

【測試工程思考】測試自動化基礎能力建設

1 回顧 傳統軟件研發體系下定義的軟件測試是從用戶視角設計的。測試是試圖窮盡用戶行為的工程,從測試用例(use case)的英文定義就可見一般。測試的邏輯資產就是用自然語言去描述用戶的操作行為或路徑。 但隨著軟件工程向分布式架構和敏捷交付…

進階向:AI聊天機器人(NLP+DeepSeek API)

什么是AI聊天機器人? AI聊天機器人是一種通過自然語言處理(NLP)技術模擬人類對話的智能程序系統。其核心是建立在機器學習算法和大型語言模型基礎上的對話引擎,能夠理解用戶的自然語言輸入,分析語境和意圖,并生成符合上下文的相關回復。 這類機器人系統通常包含以下幾個…

一個C#的段子

猜猜按鈕的結果是啥。 public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { } public static bool flag true; privat…

使用 gptqmodel 量化 Qwen3-Coder-30B-A3B-Instruct

代碼部分 : quantize_qwen3_coder_30b_a3b_instruct_gptq.py import os########## 環境變量設置 ########## # 當前可用的 CUDA 編號 os.environ["CUDA_VISIBLE_DEVICES"] "1" # GPU 顯存資源片段優化 os.environ["PYTORCH_CUDA_ALLOC_CONF"] …

基于python、django的疫苗接種管理系統

基于python、django的疫苗接種管理系統

Go語言實戰案例:使用sync.Map構建線程安全map

在并發編程中,共享資源的訪問是一個繞不開的問題。Go 中的 map 在并發讀寫時是不安全的,直接使用可能導致程序 panic。因此,在多協程同時訪問 Map 的場景下,必須采取有效的同步措施。本篇將通過一個實戰案例,介紹 Go 的…

關于vue2中對接海康攝像頭以及直播流rtsp或rtmp,后臺ffmpeg轉碼后通過ws實現

最近項目中需要對接攝像頭監控,海康攝像頭為rtsp流格式有一個軟件VLC media player,可以在線進行rtsp或者rtmp流播放,可用來測試流地址是否可用功能實現思路為后臺通過fmpeg把rtsp流進行轉碼,然后通過ws方式進行一幀一幀推送。&am…

Docker容器強制刪除及文件系統修復完整指南

Docker容器強制刪除及文件系統修復完整指南 故障現象與原因分析 ?故障表現?: ERROR: for c9ca40be974d_OpIsosMD_OB unable to remove filesystem unlinkat /data/docker/storage/containers/c9ca40be974d...: structure needs cleaning?根本原因?:…