1. 下载和安装
# 确保目录存在
mkdir -p /usr/local/share/
cd /usr/local/share/
# 下载安装包 (版本看官网)
curl -# -O https://ftp.postgresql.org/pub/source/v15.7/postgresql-15.7.tar.bz2
# 2025yum源不可用!!!! 切换yum源,回车、回车 下一步
bash <(curl -sSL https://gitee.com/SuperManito/LinuxMirrors/raw/main/ChangeMirrors.sh)
# 下载编译所需依赖
yum -y install gcc make libicu-devel readline-devel zlib-devel openssl-devel libxml2-devel bzip2
# 解压源码包
tar jxvf postgresql-15.7.tar.bz2 -C /usr/local/share/
# 进入源码目录
cd /usr/local/share/postgresql-15.7
# 配置安装路径
./configure --prefix=/usr/local/share/postgresql-15.7
# 编译(可选加 -j 并行编译)
make
# 安装
sudo make install
2. 配置相关环境变量和数据目录、日志目录、数据用户等
# 创建专属用户 并设置密码:123456
useradd postgres
echo "123456" | passwd --stdin postgres
# 创建数据和日志目录
mkdir -p /usr/local/share/postgresql-15.7/{data,log}
# 绑定目录所属
chown -R postgres.postgres /usr/local/share/postgresql-15.7
# 保证系统可执行 (如果没有bin目录 mkdir -p /usr/local/bin/)
ln -s /usr/local/share/postgresql-15.7/bin/* /usr/local/bin
# 使用非root用户进行数据库初始化
su - postgres
/usr/local/share/postgresql-15.7/bin/initdb -D /usr/local/share/postgresql-15.7/data
# 编辑配置基础文件
vim /usr/local/share/postgresql-15.7/data/postgresql.conf
# -----------------------------------------------------------------------------
listen_addresses = '*' # 监听所有网段 , 默认监听本机
port = 5432 # 监听的TCP端口号 , 默认值5432
max_connections = 100 # 最大连接数 , 默认值100
log_directory = '/usr/local/share/postgresql-15.7/log' # log日志存放路径
# -----------------------------------------------------------------------------
# 编辑配置权限文件
vim /usr/local/share/postgresql-15.7/data/pg_hba.conf
# -----------------------------------------------------------------------------
# 表示那个用户 可以使用什么方式【本地(local)/远程(host)】访问 那个数据库,是否需要密码(trust不需要/md5需要)
# 如果是生产的 请使用类似下面的(CIDR表示法)区分网段
# host sonar sonar 192.168.208.10/24 trust
# 我这里为了方便 允许任意用户可连接
host all all 0.0.0.0/0 md5
host all all ::/0 md5
# -----------------------------------------------------------------------------
# 换回root用户进行环境变量配置(shell 脚本的运行需要使用变量)
exit
vim /etc/profile
# -----------------------------------------------------------------------------
export PGHOME=/usr/local/share/postgresql-15.7
export PGDATA=/usr/local/share/postgresql-15.7/data
export PGPORT=5432
export PGUSER=postgres
export PATH=$PATH:$PGHOME/bin
# -----------------------------------------------------------------------------
# 刷新环境变量
source /etc/profile
# ===============使用shell 配置systemd===============
cd /
vim postgresql_service.sh
# -----------------------------------------------------------------------------
#!/bin/bash
create_postgresql_service() {
# 如果 PGUSER 或 PGDATA 未设置,使用默认值
: ${PGUSER:=postgres}
: ${PGDATA:=/usr/local/share/postgresql-15.7/data}
cat > /usr/lib/systemd/system/postgresql.service <<-EOF
[Unit]
Description=PostgreSQL database server
Documentation=https://www.postgresql.org/docs/15/index.html
After=network.target
[Service]
User=$PGUSER
Group=$PGUSER
Type=forking
ExecStart=/usr/local/share/postgresql-15.7/bin/pg_ctl -D $PGDATA start
ExecStop=/usr/local/share/postgresql-15.7/bin/pg_ctl -D $PGDATA stop -m fast
Restart=always
TimeoutSec=300
[Install]
WantedBy=multi-user.target
EOF
}
echo "PostgreSQL systemd service file created at /usr/lib/systemd/system/postgresql.service"
# 执行函数创建服务文件
create_postgresql_service
# 重新加载 systemd
systemctl daemon-reload
echo "Systemd configuration reloaded. You can now enable and start PostgreSQL:"
echo "启动服务:sudo systemctl start postgresql"
echo "开机自启:sudo systemctl enable postgresql"
# -----------------------------------------------------------------------------
# ===============启动PostgreSQL===============
# 赋予postgresql_service.sh 可执行权限
chmod -R 777 postgresql_service.sh
# 执行
sh postgresql_service.sh
# 启动
sudo systemctl start postgresql
# 开机自启
sudo systemctl enable postgresql
# ===============准备数据库及用户===============
# 进入pg命令控制台
psql
# 创建新用户
postgres=# CREATE ROLE sonar WITH LOGIN PASSWORD '123456';
# 创建名为sonar 数据库
postgres=# CREATE DATABASE sonar OWNER sonar;
# 授予数据库访问权限
postgres=# GRANT ALL PRIVILEGES ON DATABASE sonar TO sonar;
# 退出
postgres=# \q
# 创建专属数据库用户
useradd sonar
echo "123456" | passwd --stdin sonar
vim /etc/sudoers
# -----------------------------------------------------------------------------
sonar ALL=(ALL) ALL
# -----------------------------------------------------------------------------
补充:如果安装过程有出现错乱,可以考虑重新安装
# 删除bin 目录
rm -rf /usr/local/share/postgresql-15.7/bin
# 清理目录 data/ 和log/的数据
rm -rf /usr/local/share/postgresql-15.7/data/*
rm -rf /usr/local/share/postgresql-15.7/log/*
# 清理编译文件
cd /usr/local/share/postgresql-15.7/
make clean
# 重复之前的安装操作完成安装。 如果是文件损坏,有必要重新下载安装包