2025 Centos 安装PostgreSQL

  1. 下载和安装
javascript 复制代码
# 确保目录存在
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
  1. 配置相关环境变量和数据目录、日志目录、数据用户等
javascript 复制代码
# 创建专属用户 并设置密码: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

# -----------------------------------------------------------------------------

补充:如果安装过程有出现错乱,可以考虑重新安装

javascript 复制代码
# 删除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

# 重复之前的安装操作完成安装。 如果是文件损坏,有必要重新下载安装包
相关推荐
Johny_Zhao几秒前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
小毛驴85032 分钟前
Linux 后台启动java jar 程序 nohup java -jar
java·linux·jar
好好学习啊天天向上2 小时前
世上最全:ubuntu 上及天河超算上源码编译llvm遇到的坑,cmake,ninja完整过程
linux·运维·ubuntu·自动性能优化
tan180°3 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
典学长编程3 小时前
Linux操作系统从入门到精通!第二天(命令行)
linux·运维·chrome
wuk9983 小时前
基于MATLAB编制的锂离子电池伪二维模型
linux·windows·github
DuelCode4 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
独行soc6 小时前
#渗透测试#批量漏洞挖掘#HSC Mailinspector 任意文件读取漏洞(CVE-2024-34470)
linux·科技·安全·网络安全·面试·渗透测试
BD_Marathon6 小时前
Ubuntu下Tomcat的配置
linux·ubuntu·tomcat
饥饿的半导体6 小时前
Linux快速入门
linux·运维