#!/bin/bash export PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:$PATH : ' Copyright (C) 2022 - now HaoZi Technology Co., Ltd. This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see <https://www.gnu.org/licenses/>. ' source <(curl -f -s --connect-timeout 10 --retry 3 https://dl.cdn.haozi.net/panel/public.sh) if [ $? -ne 0 ]; then echo "下载 public.sh 失败,请检查网络或稍后重试。" echo "Download public.sh failed, please check the network or try again later." exit 1 fi channel=${1} version=${2} minio_path="${setup_path}/server/minio" if [ ! -d "${minio_path}" ]; then mkdir -p ${minio_path} fi minio_user_check=$(cat /etc/passwd | grep minio) if [ "${minio_user_check}" == "" ]; then groupadd minio useradd -s /sbin/nologin -g minio minio fi # 架构判断 if [ ${ARCH} == "x86_64" ]; then minio_file="minio-${version}-amd64.7z" elif [ ${ARCH} == "aarch64" ]; then minio_file="minio-${version}-arm64.7z" else error "不支持的架构" fi # 下载 cd ${minio_path} wget --retry-connrefused --retry-on-host-error --retry-on-http-error=429,500,502,503,504 -t 10 -T 120 -O ${minio_path}/${minio_file} ${download_url}/minio/${minio_file} wget --retry-connrefused --retry-on-host-error --retry-on-http-error=429,500,502,503,504 -t 10 -T 120 -O ${minio_path}/${minio_file}.sha256 ${download_url}/minio/${minio_file}.sha256 if ! sha256sum --status -c ${minio_path}/${minio_file}.sha256; then rm -rf ${minio_path} error "minio 校验失败" fi # 解压 cd ${minio_path} 7z x ${minio_file} rm -f ${minio_file} ${minio_file}.sha256 mv minio-${version}-* minio if [ ! -f "${minio_path}/minio" ]; then rm -rf ${minio_path} error "minio 解压失败" fi # 初始化目录 mkdir -p ${minio_path}/data chown -R minio:minio ${minio_path} chmod -R 700 ${minio_path} ln -sf ${minio_path}/minio /usr/local/bin/minio # 配置systemd cat >/etc/systemd/system/minio.service <<EOF [Unit] Description=MinIO Documentation=https://docs.min.io Wants=network-online.target After=network-online.target AssertFileIsExecutable=/usr/local/bin/minio AssertFileNotEmpty=/etc/default/minio [Service] Type=notify WorkingDirectory=${minio_path}/ User=minio Group=minio ProtectProc=invisible EnvironmentFile=/etc/default/minio ExecStart=/usr/local/bin/minio server \$MINIO_OPTS \$MINIO_VOLUMES # Let systemd restart this service always Restart=always # Specifies the maximum file descriptor number that can be opened by this process LimitNOFILE=1048576 # Specifies the maximum number of threads this process can create TasksMax=infinity # Disable timeout logic and wait until process is stopped TimeoutSec=infinity # Disable killing of MinIO by the kernel's OOM killer OOMScoreAdjust=-1000 SendSIGKILL=no [Install] WantedBy=multi-user.target EOF # 环境变量 root_user=$(cat /dev/urandom | head -n 16 | md5sum | head -c 8) root_password=$(cat /dev/urandom | head -n 16 | md5sum | head -c 16) cat >/etc/default/minio <<EOF # MINIO_ROOT_USER and MINIO_ROOT_PASSWORD sets the root account for the MinIO server. # This user has unrestricted permissions to perform S3 and administrative API operations on any resource in the deployment. # Omit to use the default values 'minioadmin:minioadmin'. # MinIO recommends setting non-default values as a best practice, regardless of environment MINIO_ROOT_USER=${root_user} MINIO_ROOT_PASSWORD=${root_password} # MINIO_VOLUMES sets the storage volume or path to use for the MinIO server. MINIO_VOLUMES="${minio_path}/data" # MINIO_OPTS sets any additional commandline options to pass to the MinIO server. # For example, \$(--console-address :9001) sets the MinIO Console listen port MINIO_OPTS="--console-address :9001" EOF chmod 600 /etc/default/minio chown minio:minio /etc/default/minio systemctl daemon-reload systemctl enable --now minio if [ "$?" != "0" ]; then error "启动失败" fi # 防火墙 firewall-cmd --zone=public --add-port=9000/tcp --permanent firewall-cmd --zone=public --add-port=9001/tcp --permanent firewall-cmd --reload panel-cli app write minio ${channel} ${version} echo -e $HR echo "minio 安装完成,默认账号见环境变量" echo -e $HR