今天主要介绍minio的一键安装脚本,包括shell和python。
一、MinIO 简介
MinIO 是一个高性能的对象存储服务器,兼容 Amazon S3 接口。它是用 Go 语言编写的,旨在满足大规模数据存储和处理需求。MinIO 提供了简洁且强大的 API,使其成为构建现代数据基础设施的理想选择。
主要特点:
高性能:MinIO 以高性能著称,适合大规模的数据湖和分析工作负载。
S3 兼容:完全兼容 Amazon S3 API,使得现有的 S3 客户端和工具可以无缝地与 MinIO 交互。
弹性伸缩:支持分布式部署,可以轻松扩展存储容量。
安全性:提供基于 SSL/TLS 的加密传输,同时支持服务器端和客户端加密。
简单性:安装和配置极其简单,可在几分钟内启动和运行。
MinIO 使用场景
私有云存储:
使用场景:企业内部部署 MinIO,用于存储和管理各类文件和数据。
优势:数据保持在企业内部,符合数据安全和隐私保护要求。
混合云存储:
使用场景:结合公有云存储(如 Amazon S3)和私有云存储的方案,通过 MinIO 实现数据同步和迁移。
优势:既利用了公有云的弹性和可扩展性,又保留了私有云的数据控制权。
数据湖和大数据分析:
使用场景:将 MinIO 用作数据湖,存储海量结构化、半结构化和非结构化数据,方便后续的大数据分析和处理。
优势:高性能的对象存储支持快速的数据读取和写入,兼容多种大数据处理框架。
备份与恢复:
使用场景:使用 MinIO 存储备份数据,包括数据库备份、虚拟机快照等,并在需要时进行恢复。
优势:支持版本控制、对象锁定等功能,有效管理备份数据。
内容分发网络 (CDN):
使用场景:作为 CDN 源站存储静态内容(如图片、视频、文档),通过 CDN 节点进行全球分发。
优势:高可用性和高性能保证了内容的快速分发。
微服务架构中的共享存储:
使用场景:微服务架构中,各个服务需要共享存储资源来管理文件上传、下载和数据交换。
优势:统一的对象存储接口,简化了文件管理和跨服务的数据访问。
AI/ML 数据存储:
使用场景:存储用于训练和推理的 AI/ML 数据集,支持大规模数据的并行处理和访问。
优势:高性能存储和快速的数据访问,加速模型训练和推理过程。
二、shell脚本
#!/bin/bash
# 检查是否以 root 用户运行
if [ "$EUID" -ne 0 ]; then
echo "请以 root 用户运行此脚本。"
exit 1
fi
# 安装必要的依赖
echo "安装依赖..."
apt-get update && apt-get install -y wget || yum install -y wget
# 定义 MinIO 版本和安装路径
MINIO_VERSION="RELEASE.2023-09-19T21-14-04Z"
MINIO_URL="https://dl.min.io/server/minio/release/linux-amd64/archive/minio.${MINIO_VERSION}"
# 创建 MinIO 安装目录
mkdir -p /usr/local/bin
# 下载并安装 MinIO
echo "下载并安装 MinIO..."
wget -q -O /usr/local/bin/minio $MINIO_URL
chmod +x /usr/local/bin/minio
# 创建 MinIO 数据目录
mkdir -p /usr/local/share/minio
# 设置环境变量
ACCESS_KEY="minioadmin"
SECRET_KEY="minioadmin"
# 创建 MinIO systemd service 文件
cat <<EOL > /etc/systemd/system/minio.service
[Unit]
Description=MinIO
Documentation=https://docs.min.io
Wants=network-online.target
After=network-online.target
[Service]
User=root
Group=root
Environment="MINIO_ACCESS_KEY=${ACCESS_KEY}"
Environment="MINIO_SECRET_KEY=${SECRET_KEY}"
ExecStart=/usr/local/bin/minio server /usr/local/share/minio
Restart=always
LimitNOFILE=65536
[Install]
WantedBy=multi-user.target
EOL
# 重载 systemd 服务
systemctl daemon-reload
# 启动并启用 MinIO 服务
echo "启动并启用 MinIO 服务..."
systemctl enable --now minio
# 提示安装完成
echo "MinIO 安装完成并已启动。"
echo "可以通过 http://<你的服务器IP>:9000 访问 MinIO 控制台。"
echo "默认访问密钥(Access Key):${ACCESS_KEY}"
echo "默认私密钥(Secret Key):${SECRET_KEY}"
三、python脚本
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import os
import time
def install():
"""
安装 RELEASE
过程:
cp ./minio /usr/bin/
chmod +x /usr/bin/minio
mkdir /var/log/minio
nohup minio server /mnt/data --console-address ":9001" > /var/log/minio/minio.log 2>&1 &
:return:
"""
os.system("cp ./minio /usr/bin/")
os.system("chmod +x /usr/bin/minio")
os.mkdir("/var/log/minio")
os.system("nohup minio server /mnt/data --console-address \":9001\" > /var/log/minio/minio.log 2>&1 &")
def detect():
"""
检测是否安装成功
:return:
"""
time.sleep(5)
return True if os.popen("ps -ef|grep minio").read().find(
"minio server") > 0 else False
def prompt_fail():
"""
安装失败后提示
:return:
"""
print """
\033[5;31;40m 安装失败 \033[0m
"""
def prompt_success():
"""
安装成功后提示
:return:
"""
print """
\033[5;32;40m minio安装成功!\033[0m
使用前注意:
账号:minioadmin
密码:minioadmin
默认安装路径:/usr/bin/minio
默认文件存储路径:/mnt/data
默认日志文件路径:/var/log/minio/minio.log
控制台访问地址:http://ip:9001
后台启动命令:
nohup minio server 文件存储路径 --console-address \":9001\" > /var/log/minio/minio.log 2>&1 &
如:nohup minio server /mnt/data --console-address \":9001\" > /var/log/minio/minio.log 2>&1 &
minio已经安装成功,进程检测无异常。
如果是无法访问控制台,可能是防火墙导致的,可以执行:
systemctl stop firewalld
"""
if __name__ == '__main__':
install()
if detect():
prompt_success()
else:
prompt_fail()
注意:两个脚本都需要赋予X执行权限。然后在目录下执行安装脚本即可。