mirror of
https://github.com/acepanel/panel.git
synced 2026-02-04 06:40:59 +08:00
192 lines
6.5 KiB
Bash
192 lines
6.5 KiB
Bash
#!/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/>.
|
||
'
|
||
|
||
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://jihulab.com/haozi-team/download/-/raw/main/panel/postgresql"
|
||
setupPath="/www"
|
||
postgresqlPath="${setupPath}/server/postgresql"
|
||
postgresqlVersion=""
|
||
cpuCore=$(cat /proc/cpuinfo | grep "processor" | wc -l)
|
||
|
||
if [[ "${1}" == "15" ]]; then
|
||
postgresqlVersion="15.4"
|
||
elif [[ "${1}" == "16" ]]; then
|
||
postgresqlVersion="16.0"
|
||
else
|
||
echo -e $HR
|
||
echo "错误:不支持的 PostgreSQL 版本!"
|
||
exit 1
|
||
fi
|
||
|
||
# 安装依赖
|
||
if [ "${OS}" == "centos" ]; then
|
||
dnf makecache -y
|
||
dnf groupinstall "Development Tools" -y
|
||
dnf install make gettext zlib-devel readline-devel libicu-devel libxml2-devel libxslt-devel openssl-devel systemd-devel -y
|
||
elif [ "${OS}" == "debian" ]; then
|
||
apt-get update
|
||
apt-get install build-essential make gettext zlib1g-dev libreadline-dev libicu-dev libxml2-dev libxslt-dev libssl-dev libsystemd-dev -y
|
||
else
|
||
echo -e $HR
|
||
echo "错误:耗子Linux面板不支持该系统"
|
||
exit 1
|
||
fi
|
||
|
||
postgresqlUserCheck=$(cat /etc/passwd | grep postgres)
|
||
if [ "${postgresqlUserCheck}" == "" ]; then
|
||
groupadd postgres
|
||
useradd -g postgres postgres
|
||
fi
|
||
|
||
# 准备目录
|
||
rm -rf ${postgresqlPath}
|
||
mkdir -p ${postgresqlPath}
|
||
cd ${postgresqlPath}
|
||
|
||
# 下载源码
|
||
wget -T 120 -t 3 -O ${postgresqlPath}/postgresql-${postgresqlVersion}.tar.gz ${downloadUrl}/postgresql-${postgresqlVersion}.tar.gz
|
||
wget -T 20 -t 3 -O ${postgresqlPath}/postgresql-${postgresqlVersion}.tar.gz.checksum.txt ${downloadUrl}/postgresql-${postgresqlVersion}.tar.gz.checksum.txt
|
||
|
||
if ! sha256sum --status -c postgresql-${postgresqlVersion}.tar.gz.checksum.txt; then
|
||
echo -e $HR
|
||
echo "错误:PostgreSQL 源码 checksum 校验失败,文件可能被篡改或不完整,已终止操作"
|
||
rm -rf ${postgresqlPath}
|
||
exit 1
|
||
fi
|
||
|
||
tar -zxvf postgresql-${postgresqlVersion}.tar.gz
|
||
rm -f postgresql-${postgresqlVersion}.tar.gz
|
||
rm -f postgresql-${postgresqlVersion}.tar.gz.checksum.txt
|
||
mv postgresql-${postgresqlVersion} src
|
||
|
||
# 编译
|
||
cd src
|
||
./configure --prefix=${postgresqlPath} --enable-nls='zh_CN en' --with-icu --with-ssl=openssl --with-systemd --with-libxml --with-libxslt
|
||
if [ "$?" != "0" ]; then
|
||
echo -e $HR
|
||
echo "错误:PostgreSQL 编译初始化失败,请截图错误信息寻求帮助。"
|
||
rm -rf ${postgresqlPath}
|
||
exit 1
|
||
fi
|
||
make -j${cpuCore}
|
||
if [ "$?" != "0" ]; then
|
||
echo -e $HR
|
||
echo "错误:PostgreSQL 编译失败,请截图错误信息寻求帮助。"
|
||
rm -rf ${postgresqlPath}
|
||
exit 1
|
||
fi
|
||
make install
|
||
if [ "$?" != "0" ]; then
|
||
echo -e $HR
|
||
echo "错误:PostgreSQL 安装失败,请截图错误信息寻求帮助。"
|
||
rm -rf ${postgresqlPath}
|
||
exit 1
|
||
fi
|
||
|
||
cd ${postgresqlPath}
|
||
rm -rf ${postgresqlPath}/src
|
||
|
||
# 配置
|
||
mkdir -p ${postgresqlPath}/data
|
||
mkdir -p ${postgresqlPath}/logs
|
||
chown -R postgres:postgres ${postgresqlPath}
|
||
chmod -R 700 ${postgresqlPath}
|
||
|
||
echo "export PATH=${postgresqlPath}/bin:\$PATH" >> /etc/profile
|
||
source /etc/profile
|
||
|
||
mkdir -p /home/postgres
|
||
cd /home/postgres
|
||
if [ -f /home/postgres/.bash_profile ]; then
|
||
echo "export PGHOME=${postgresqlPath}" >> /home/postgres/.bash_profile
|
||
echo "export PGDATA=${postgresqlPath}/data" >> /home/postgres/.bash_profile
|
||
echo "export PATH=${postgresqlPath}/bin:\$PATH " >> /home/postgres/.bash_profile
|
||
echo "MANPATH=$PGHOME/share/man:$MANPATH" >> /home/postgres/.bash_profile
|
||
echo "LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH" >> /home/postgres/.bash_profile
|
||
source /home/postgres/.bash_profile
|
||
fi
|
||
if [ -f /home/postgres/.profile ]; then
|
||
echo "export PGHOME=${postgresqlPath}" >> /home/postgres/.profile
|
||
echo "export PGDATA=${postgresqlPath}/data" >> /home/postgres/.profile
|
||
echo "export PATH=${postgresqlPath}/bin:\$PATH " >> /home/postgres/.profile
|
||
echo "MANPATH=$PGHOME/share/man:$MANPATH" >> /home/postgres/.profile
|
||
echo "LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH" >> /home/postgres/.profile
|
||
source /home/postgres/.profile
|
||
fi
|
||
|
||
# 初始化
|
||
su - postgres -c "${postgresqlPath}/bin/initdb -D ${postgresqlPath}/data"
|
||
if [ "$?" != "0" ]; then
|
||
echo -e $HR
|
||
echo "错误:PostgreSQL 初始化失败,请截图错误信息寻求帮助。"
|
||
rm -rf ${postgresqlPath}
|
||
exit 1
|
||
fi
|
||
|
||
# 配置慢查询日志
|
||
cat >> ${postgresqlPath}/data/postgresql.conf << EOF
|
||
logging_collector = on
|
||
log_destination = 'stderr'
|
||
log_directory = '${postgresqlPath}/logs'
|
||
log_filename = 'postgresql-%Y-%m-%d.log'
|
||
log_statement = all
|
||
log_min_duration_statement = 5000
|
||
EOF
|
||
|
||
# 写入服务
|
||
cat > /etc/systemd/system/postgresql.service << EOF
|
||
[Unit]
|
||
Description=PostgreSQL database server
|
||
Documentation=man:postgres(1)
|
||
After=network-online.target
|
||
Wants=network-online.target
|
||
|
||
[Service]
|
||
Type=notify
|
||
User=postgres
|
||
ExecStart=${postgresqlPath}/bin/postgres -D ${postgresqlPath}/data
|
||
ExecReload=/bin/kill -HUP \$MAINPID
|
||
KillMode=mixed
|
||
KillSignal=SIGINT
|
||
TimeoutSec=infinity
|
||
|
||
[Install]
|
||
WantedBy=multi-user.target
|
||
EOF
|
||
|
||
# 在 /etc/systemd/logind.conf 设置 RemoveIPC=no,不然会删除 /dev/shm 下的共享内存文件
|
||
checkRemoveIPC=$(cat /etc/systemd/logind.conf | grep '^RemoveIPC=no.*$')
|
||
if [ "${checkRemoveIPC}" == "" ]; then
|
||
echo "RemoveIPC=no" >> /etc/systemd/logind.conf
|
||
systemctl restart systemd-logind
|
||
fi
|
||
|
||
# 启动服务
|
||
systemctl daemon-reload
|
||
systemctl enable postgresql
|
||
systemctl start postgresql
|
||
|
||
panel writePlugin postgresql${1} ${postgresqlVersion}
|
||
|
||
echo -e "${HR}\nPostgreSQL-${1} 安装完成\n${HR}"
|