前言
- minio单节点容器部署
- s3fs本地挂载minio桶(单个)
- linux环境 ubuntu or debain
- python3.8.10
中间耦合过多。但是,linux开机自启(systemctl外还有别的实现方式)通过python脚本运行linux命令。在以后可能是一个不错的选择。 实现 通过s3fs将minio桶上存储的路径挂载到某个路径下。linux重启在minio启动后自动挂载。
minio
docker-compose
容器部署
version: '3'
services:
minio:
image: 'minio/minio:latest'
container_name: minio
restart: always
command: server /data --console-address ":9001"
environment:
- MINIO_ROOT_USER=minioadmin
- MINIO_ROOT_PASSWORD=minioadmin
ports:
- "9001:9001"
- "9000:9000"
s3fs
安装
sudo apt install s3fs
配置
配置minio账号密码
echo AccessKey:SecretKey > xx/passwd-s3fs
chmod 600 xx/.passwd-s3fs
手动挂载
s3fs -o passwd_file=/xx/.passwd-s3fs -o url=http://ip:9000 -o allow_other -o no_check_certificate -o use_path_request_style -o umask=000 minio桶名称 挂载路径
linux服务器重启自动挂载minio桶
ubuntu/debian 适用
方法
systemctl开机自启,运行python脚本。
在路径**/usr/lib/systemd/system** or /etc/systemd/system 配置minio.service文件。
[Unit]
Description=minio
Documentation=empty
[Service]
Type=oneshot
PIDFile=/run/minio.pid
ExecStartPre=
# python脚本
ExecStart=/usr/bin/python3 xx/minio_bucket_monut.py.py
ExecReload=
ExecStop=
PrivateTmp=true
[Install]
WantedBy=multi-user.target
设置开启自启动
systemctl enable minio.service
python脚本
- 监测minio容器状态为运行
- 挂载minio桶
- 可以重启部分容器
- 脚本默认循环 600 次 每次等待1s
minio_bucket_monut.py
import subprocess
from time import sleep
def execute(command):
"""执行"""
try:
return subprocess.getoutput(command)
except Exception as e:
print(e)
def run_linux(
minio_container_name,
minio_pw_path,
minio_url,
bucket_name,
mount_path,
containers: [list, tuple] = None,
sleep_num=1,
count=600
):
"""
linux 开机启动 python 脚本 监控 docker容器状态
:param minio_container_name: minio 容器名称
:param minio_pw_path: minio 用户名密码和账号文件路径
:param minio_url: minio服务url
:param bucket_name: 挂载minio桶名称
:param mount_path: 挂载地址
:param containers: 重启容器名称
:param sleep_num: 循环一次睡眠时间
:param count: 循环次数
sleep_num * count = 监听最长时间 s
:return:
"""
# sudo docker inspect --format '{{.Name}} {{.State.Running}} 容器名称' -> '/minio true'
c1 = "sudo docker inspect --format '{{.State.Running}}' %s" % minio_container_name
c2 = f"s3fs -o passwd_file={minio_pw_path} -o url={minio_url} -o allow_other -o no_check_certificate " \
f"-o use_path_request_style -o umask=000 {bucket_name} {mount_path}"
i = 0
while i < count:
res = execute(c1)
if not res:
break
if res == 'true':
# 挂载 s3fs
execute(c2)
# 重启 容器
if containers is not None:
for ite in containers:
execute(
'sudo docker restart %s' % ite
)
break
sleep(sleep_num)
i += 1
if __name__ == '__main__':
conf = {
'minio_container_name': 'minio',
'minio_pw_path': '/xx/.passwd-s3fs',
'minio_url': 'http://ip:9000',
'bucket_name': 'bucket_name',
'mount_path': 'mount_path',
'containers': ['容器名称1', '容器名称2'],
}
run_linux(**conf)