PostgreSQL 16.1 安装指南

环境准备

1. 系统检查

bash 复制代码
# 查看系统版本
cat /etc/redhat-release

# 检查磁盘空间
df -Th

2. 创建目录结构

bash 复制代码
mkdir -p /pgccc/soft        # 软件包存放目录
mkdir -p /pgccc/app         # PostgreSQL安装目录
mkdir -p /pgccc/pgdata      # 数据目录
mkdir -p /pgccc/archive     # 归档目录
mkdir -p /pgccc/backups     # 备份目录

3. 创建用户和组

bash 复制代码
groupadd postgres
useradd -g postgres postgres
echo "postgres" | passwd --stdin postgres

# 设置目录权限
chown -R postgres. /pgccc
chmod -R 775 /pgccc

安装依赖包

配置本地YUM源

bash 复制代码
# 挂载ISO镜像
mount /dev/cdrom /mnt

# 创建本地YUM源脚本(set_local_yum.sh)
# 脚本内容需根据实际情况编写
sh set_local_yum.sh /mnt

安装编译依赖

bash 复制代码
yum install -y bison flex readline-devel zlib zlib-devel gcc \
               openssl-devel libicu-devel

编译安装PostgreSQL

1. 解压源码包

bash 复制代码
cd /pgccc/soft
tar zxvf postgresql-16.1.tar.gz
cd postgresql-16.1

2. 配置编译选项

bash 复制代码
./configure --prefix=/pgccc/app/16.1 \
            --with-pgport=1521 \
            --with-blocksize=8 \
            --with-wal-blocksize=8 \
            --with-segsize=5

3. 编译和安装

bash 复制代码
make && make install

配置系统服务

1. 创建systemd服务文件

bash 复制代码
vi /usr/lib/systemd/system/postgresql-16.service

服务文件内容示例:

ini 复制代码
[Unit]
Description=PostgreSQL 16.1 database server
After=network.target

[Service]
Type=forking
User=postgres
Group=postgres
Environment=PGDATA=/pgccc/pgdata
OOMScoreAdjust=-1000
ExecStart=/pgccc/app/16.1/bin/pg_ctl -D ${PGDATA} start
ExecStop=/pgccc/app/16.1/bin/pg_ctl -D ${PGDATA} stop
ExecReload=/pgccc/app/16.1/bin/pg_ctl -D ${PGDATA} reload
TimeoutSec=300

[Install]
WantedBy=multi-user.target

2. 配置服务

bash 复制代码
# 重载systemd配置
systemctl daemon-reload

# 设置数据目录权限
chmod 0700 /pgccc/pgdata

# 启动服务
systemctl start postgresql-16.service

# 设置开机自启
systemctl enable postgresql-16.service

系统优化配置

1. 关闭SELinux

bash 复制代码
# 临时关闭
setenforce 0

# 永久关闭
sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config

# 验证状态
getenforce

2. 关闭防火墙

bash 复制代码
systemctl stop firewalld
systemctl disable firewalld

故障排查

查看服务状态

bash 复制代码
# 检查服务状态
systemctl status postgresql-16.service

# 查看服务日志
journalctl -xeu postgresql-16.service

# 检查进程
ps -ef | grep post

常见问题解决

  1. 权限问题 :确保/pgccc/pgdata目录权限为0700
  2. SELinux阻止:检查并关闭SELinux
  3. 端口冲突:检查1521端口是否被占用

环境变量配置(可选)

/etc/profile~/.bash_profile中添加:

bash 复制代码
export PGHOME=/pgccc/app/16.1
export PGDATA=/pgccc/pgdata
export PATH=$PGHOME/bin:$PATH
export LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH

验证安装

bash 复制代码
# 切换到postgres用户
su - postgres

# 连接到数据库(需要先初始化数据库)
/pgccc/app/16.1/bin/psql -p 1521

注意事项

  1. 安装前确保有足够的磁盘空间
  2. 生产环境建议使用更安全的密码
  3. 根据实际需求调整编译参数
  4. 定期备份重要数据
  5. 监控数据库运行状态

后续步骤

  1. 初始化数据库集群
  2. 配置pg_hba.conf访问控制
  3. 调整postgresql.conf参数
  4. 创建数据库用户和数据库
  5. 配置归档和备份策略

本指南基于CentOS/RedHat系统编写,其他Linux发行版可能略有不同

相关推荐
weelinking1 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934612 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋93 小时前
windows中安装redis
数据库·redis·缓存
Cosolar3 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap3 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel3 小时前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特4 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_4 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze5 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库
2301_803934615 小时前
MySQL 字段类型选择规范指南
jvm·数据库·python