mirror of
https://github.com/acepanel/panel.git
synced 2026-02-05 02:07:18 +08:00
299 lines
13 KiB
Bash
299 lines
13 KiB
Bash
#!/bin/bash
|
||
export PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:$PATH
|
||
|
||
: '
|
||
Copyright 2022 HaoZi Technology Co., Ltd.
|
||
|
||
Licensed under the Apache License, Version 2.0 (the "License");
|
||
you may not use this file except in compliance with the License.
|
||
You may obtain a copy of the License at
|
||
|
||
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
||
Unless required by applicable law or agreed to in writing, software
|
||
distributed under the License is distributed on an "AS IS" BASIS,
|
||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
See the License for the specific language governing permissions and
|
||
limitations under the License.
|
||
'
|
||
|
||
HR="+----------------------------------------------------"
|
||
ARCH=$(uname -m)
|
||
memTotal=$(LC_ALL=C free -m | grep Mem | awk '{print $2}')
|
||
OS=$(source /etc/os-release && { [[ "$ID" == "debian" ]] && echo "debian"; } || { [[ "$ID" == "centos" ]] || [[ "$ID" == "rhel" ]] || [[ "$ID" == "rocky" ]] || [[ "$ID" == "almalinux" ]] && echo "centos"; } || echo "unknown")
|
||
downloadUrl="https://dl.cdn.haozi.net/panel/mysql"
|
||
setupPath="/www"
|
||
mysqlPath="${setupPath}/server/mysql"
|
||
mysqlVersion=""
|
||
mysqlPassword=$(cat /dev/urandom | head -n 16 | md5sum | head -c 16)
|
||
cpuCore=$(cat /proc/cpuinfo | grep "processor" | wc -l)
|
||
|
||
if [[ "${1}" == "80" ]]; then
|
||
mysqlVersion="8.0.33"
|
||
elif [[ "${1}" == "57" ]]; then
|
||
mysqlVersion="5.7.42"
|
||
else
|
||
echo -e $HR
|
||
echo "错误:不支持的 MySQL 版本!"
|
||
exit 1
|
||
fi
|
||
|
||
if [[ "${memTotal}" -lt "4096" ]] && [[ "${1}" == "80" ]]; then
|
||
echo -e $HR
|
||
echo "错误:这点内存(${memTotal}M)还想装 MySQL 8.0?洗洗睡吧!"
|
||
exit 1
|
||
fi
|
||
|
||
# 安装依赖
|
||
if [ "${OS}" == "centos" ]; then
|
||
dnf install dnf-plugins-core -y
|
||
dnf install epel-release -y
|
||
dnf config-manager --set-enabled epel
|
||
dnf config-manager --set-enabled PowerTools
|
||
dnf config-manager --set-enabled powertools
|
||
dnf config-manager --set-enabled CRB
|
||
dnf config-manager --set-enabled Crb
|
||
dnf config-manager --set-enabled crb
|
||
/usr/bin/crb enable
|
||
dnf makecache
|
||
dnf groupinstall "Development Tools" -y
|
||
dnf install cmake bison ncurses-devel libtirpc-devel openssl-devel pkg-config openldap-devel libudev-devel cyrus-sasl-devel patchelf -y
|
||
elif [ "${OS}" == "debian" ]; then
|
||
apt update
|
||
apt install build-essential cmake bison libncurses5-dev libtirpc-dev libssl-dev pkg-config libldap2-dev libudev-dev libsasl2-dev patchelf -y
|
||
else
|
||
echo -e $HR
|
||
echo "错误:耗子Linux面板不支持该系统"
|
||
exit 1
|
||
fi
|
||
|
||
mysqlUserCheck=$(cat /etc/passwd | grep mysql)
|
||
if [ "${mysqlUserCheck}" == "" ]; then
|
||
groupadd mysql
|
||
useradd -s /sbin/nologin -g mysql mysql
|
||
fi
|
||
|
||
# 准备目录
|
||
rm -rf ${mysqlPath}
|
||
mkdir -p ${mysqlPath}
|
||
cd ${mysqlPath}
|
||
|
||
# 下载源码
|
||
wget -T 120 -O ${mysqlPath}/mysql-${mysqlVersion}.tar.gz ${downloadUrl}/mysql-boost-${mysqlVersion}.tar.gz
|
||
tar -zxvf mysql-${mysqlVersion}.tar.gz
|
||
rm -f mysql-${mysqlVersion}.tar.gz
|
||
mv mysql-${mysqlVersion} src
|
||
|
||
# openssl
|
||
wget -T 120 -O ${mysqlPath}/openssl-1.1.1u.tar.gz ${downloadUrl}/openssl/openssl-1.1.1u.tar.gz
|
||
tar -zxvf openssl-1.1.1u.tar.gz
|
||
rm -f openssl-1.1.1u.tar.gz
|
||
mv openssl-1.1.1u openssl
|
||
cd openssl
|
||
./config --prefix=/usr/local/openssl-1.1 --openssldir=/usr/local/openssl-1.1
|
||
make -j$(nproc)
|
||
make install
|
||
echo "/usr/local/openssl-1.1/lib" > /etc/ld.so.conf.d/openssl-1.1.conf
|
||
ldconfig
|
||
cd ..
|
||
rm -rf openssl
|
||
|
||
# 编译
|
||
cd src
|
||
mkdir build
|
||
cd build
|
||
cmake .. -DCMAKE_INSTALL_PREFIX=${mysqlPath} -DMYSQL_DATADIR=${mysqlPath}/data -DSYSCONFDIR=${mysqlPath}/conf -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_EXTRA_CHARSETS=all -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci -DENABLED_LOCAL_INFILE=1 -DWITH_SYSTEMD=1 -DSYSTEMD_PID_DIR=${mysqlPath} -DWITH_SSL=/usr/local/openssl-1.1 -DWITH_BOOST=../boost
|
||
|
||
if [[ "${cpuCore}" -gt "1" ]]; then
|
||
make -j2
|
||
else
|
||
make
|
||
fi
|
||
|
||
# 安装
|
||
make install
|
||
|
||
# 配置
|
||
mkdir ${mysqlPath}/conf
|
||
cat > ${mysqlPath}/conf/my.cnf << EOF
|
||
[client]
|
||
port = 3306
|
||
socket = /tmp/mysql.sock
|
||
|
||
[mysqld]
|
||
port = 3306
|
||
socket = /tmp/mysql.sock
|
||
datadir = ${mysqlPath}/data
|
||
default_storage_engine = InnoDB
|
||
skip-external-locking
|
||
table_definition_cache = 400
|
||
performance_schema_max_table_instances = 400
|
||
key_buffer_size = 8M
|
||
max_allowed_packet = 1G
|
||
table_open_cache = 32
|
||
sort_buffer_size = 256K
|
||
net_buffer_length = 4K
|
||
read_buffer_size = 128K
|
||
read_rnd_buffer_size = 256K
|
||
myisam_sort_buffer_size = 4M
|
||
thread_cache_size = 4
|
||
query_cache_size = 4M
|
||
tmp_table_size = 8M
|
||
explicit_defaults_for_timestamp = 1
|
||
#skip-name-resolve
|
||
max_connections = 500
|
||
max_connect_errors = 100
|
||
open_files_limit = 65535
|
||
early-plugin-load = ""
|
||
|
||
log-bin = mysql-bin
|
||
binlog_format = mixed
|
||
server-id = 1
|
||
slow_query_log = 1
|
||
slow-query-log-file = ${mysqlPath}/mysql-slow.log
|
||
long_query_time = 3
|
||
log-error = ${mysqlPath}/mysql-error.log
|
||
|
||
innodb_data_home_dir = ${mysqlPath}/data
|
||
innodb_data_file_path = ibdata1:10M:autoextend
|
||
innodb_log_group_home_dir = ${mysqlPath}/data
|
||
innodb_buffer_pool_size = 16M
|
||
innodb_redo_log_capacity = 5M
|
||
innodb_log_buffer_size = 8M
|
||
innodb_flush_log_at_trx_commit = 1
|
||
innodb_lock_wait_timeout = 50
|
||
innodb_max_dirty_pages_pct = 90
|
||
innodb_read_io_threads = 4
|
||
innodb_write_io_threads = 4
|
||
|
||
[mysqldump]
|
||
quick
|
||
max_allowed_packet = 500M
|
||
|
||
[myisamchk]
|
||
key_buffer_size = 20M
|
||
sort_buffer_size = 20M
|
||
read_buffer = 2M
|
||
write_buffer = 2M
|
||
|
||
[mysqlhotcopy]
|
||
interactive-timeout
|
||
EOF
|
||
|
||
# 根据CPU核心数确定写入线程数
|
||
sed -i 's/innodb_write_io_threads = 4/innodb_write_io_threads = '${cpuCore}'/g' ${mysqlPath}/conf/my.cnf
|
||
sed -i 's/innodb_read_io_threads = 4/innodb_read_io_threads = '${cpuCore}'/g' ${mysqlPath}/conf/my.cnf
|
||
|
||
if [[ "${1}" == "80" ]]; then
|
||
sed -i '/query_cache_size/d' ${mysqlPath}/conf/my.cnf
|
||
fi
|
||
if [[ "${1}" == "57" ]]; then
|
||
sed -i '/innodb_redo_log_capacity/d' ${mysqlPath}/conf/my.cnf
|
||
fi
|
||
|
||
# 根据内存大小调参
|
||
if [[ ${memTotal} -gt 1024 && ${memTotal} -lt 2048 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 32M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 128#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 768K#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 768K#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 8M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 16#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 16M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 32M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 64M" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 16M#" ${mysqlPath}/conf/my.cnf
|
||
elif [[ ${memTotal} -ge 2048 && ${memTotal} -lt 4096 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 256#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 1M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 1M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 16M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 32#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 32M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 32M#" ${mysqlPath}/conf/my.cnf
|
||
elif [[ ${memTotal} -ge 4096 && ${memTotal} -lt 8192 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 512#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 2M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 2M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 32M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 64#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 512M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
elif [[ ${memTotal} -ge 8192 && ${memTotal} -lt 16384 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 1024#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 4M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 4M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 64M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 128#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 1024M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 512M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
elif [[ ${memTotal} -ge 16384 && ${memTotal} -lt 32768 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 512M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 2048#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 8M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 8M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 128M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 256#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 2048M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 1G#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
elif [[ ${memTotal} -ge 32768 ]]; then
|
||
sed -i "s#^key_buffer_size.*#key_buffer_size = 1024M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^table_open_cache.*#table_open_cache = 4096#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^sort_buffer_size.*#sort_buffer_size = 16M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^read_buffer_size.*#read_buffer_size = 16M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^myisam_sort_buffer_size.*#myisam_sort_buffer_size = 256M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^thread_cache_size.*#thread_cache_size = 512#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^query_cache_size.*#query_cache_size = 512M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^tmp_table_size.*#tmp_table_size = 512M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_buffer_pool_size.*#innodb_buffer_pool_size = 4096M#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_redo_log_capacity.*#innodb_redo_log_capacity = 2G#" ${mysqlPath}/conf/my.cnf
|
||
sed -i "s#^innodb_log_buffer_size.*#innodb_log_buffer_size = 512M#" ${mysqlPath}/conf/my.cnf
|
||
fi
|
||
|
||
chmod 644 ${mysqlPath}/conf/my.cnf
|
||
chown -R mysql:mysql ${mysqlPath}
|
||
chmod -R 755 ${mysqlPath}
|
||
|
||
# 初始化
|
||
rm -rf ${mysqlPath}/src
|
||
rm -rf ${mysqlPath}/data
|
||
mkdir -p ${mysqlPath}/data
|
||
chown -R mysql:mysql ${mysqlPath}
|
||
chmod -R 755 ${mysqlPath}
|
||
|
||
${mysqlPath}/bin/mysqld --initialize-insecure --user=mysql --basedir=${mysqlPath} --datadir=${mysqlPath}/data
|
||
|
||
echo "export PATH=${mysqlPath}/bin:\$PATH" >> /etc/profile
|
||
source /etc/profile
|
||
|
||
# 启动
|
||
cp ${mysqlPath}/lib/systemd/system/mysqld.service /etc/systemd/system/mysqld.service
|
||
sed -i "/ExecStartPre/d" /etc/systemd/system/mysqld.service
|
||
|
||
systemctl daemon-reload
|
||
systemctl enable mysqld
|
||
systemctl start mysqld
|
||
|
||
${mysqlPath}/bin/mysqladmin -u root password ${mysqlPassword}
|
||
|
||
panel writePlugin mysqsl${1} ${mysqlVersion}
|
||
panel writeMysqlPassword ${mysqlPassword}
|
||
|
||
echo -e "${HR}\nMySQL-${1} 安装完成\n${HR}"
|