1. 准备Debian环境
确保Debian系统已更新并安装必要工具:
sudo apt update && sudo apt upgrade -y sudo apt install -y wget curl
若需通过浏览器访问MinIO控制台,需开放HTTP(9000)和HTTPS(9001)端口:
sudo ufw allow 9000/tcp sudo ufw allow 9001/tcp sudo ufw reload
2. 安装MinIO服务器
推荐通过APT包管理器安装(自动处理依赖):
sudo apt install -y minio
验证安装版本:
minio --version
3. 配置MinIO服务器
/data/minio
):sudo mkdir -p /data/minio sudo chown -R $USER:$USER /data/minio # 将目录所有权赋予当前用户
--console-address
指定控制台端口(默认9001),--address
指定API端口(默认9000):minio server /data/minio --console-address ":9001" --address ":9000"
若需开机自启,创建systemd服务文件:sudo nano /etc/systemd/system/minio.service
添加以下内容(替换/data/minio
为你的数据目录):[Unit] Description=MinIO Server After=network.target [Service] User=$USER Group=$USER Environment="MINIO_ROOT_USER=admin" # 设置访问密钥(可自定义) Environment="MINIO_ROOT_PASSWORD=admin123" # 设置秘密密钥(需强密码) ExecStart=/usr/bin/minio server /data/minio --console-address ":9001" --address ":9000" Restart=always [Install] WantedBy=multi-user.target
启用并启动服务:sudo systemctl enable minio sudo systemctl start minio
4. 安装MinIO客户端(mc)
MinIO客户端用于管理存储桶和文件,通过以下命令安装:
wget https://dl.min.io/client/mc/release/linux-amd64/mc chmod +x mc sudo mv mc /usr/local/bin/
5. 配置MinIO客户端别名
将本地MinIO服务器添加为myminio
别名(替换YOUR_SERVER_IP
为服务器IP):
mc alias set myminio http://YOUR_SERVER_IP:9000 admin admin123
验证连接:
mc ls myminio
6. 创建存储桶
存储桶是MinIO中的基本存储单元,用于分类文件:
mc mb myminio/mybucket
7. 上传文件到存储桶
将本地文件上传至指定存储桶(替换/path/to/local/file
为本地文件路径):
mc cp /path/to/local/file myminio/mybucket/
8. 实现文件共享
MinIO提供三种主要共享方式,覆盖不同场景:
http://YOUR_SERVER_IP:9001
)进入存储桶,选择目标存储桶→点击“Permissions”→设置“Public Access”为Read Only
(允许所有人读取文件)。http://YOUR_SERVER_IP:9000/mybucket/filename
(直接通过浏览器或HTTP客户端访问)。mybucket/filename
为目标文件路径):mc presigned get myminio/mybucket/filename 7d
用户可通过该链接直接下载文件(无需MinIO账户)。mybucket/filename
为目标文件路径,expiry
为有效期,如1h
表示1小时):mc share get --expire 1h myminio/mybucket/filename
输出结果包含访问链接和密码,用户可通过链接+密码访问文件。9. 安全增强(可选但推荐)
/etc/minio/certs
目录,修改MinIO启动命令添加--certs-dir /etc/minio/certs
参数,强制使用HTTPS访问。/data/minio
目录备份至其他存储设备(如NAS、云存储),避免数据丢失。sudo ufw allow from YOUR_TRUSTED_IP to any port 9000