TencentOS Server 3.3 安装 PostgreSQL 18 完整指南

适用环境:TencentOS Server 3.3(基于 RHEL / CentOS 8)

安装版本:**PostgreSQL 18.x(官方 PGDG 仓库)**​

⚠️ 系统自带 Python / 包不受影响,安全可回滚


一、清理旧仓库(如曾尝试安装过)

复制代码
复制代码
复制代码
sudo rm -f /etc/yum.repos.d/pgdg*
sudo yum clean all

二、安装 PostgreSQL 官方 EL8 仓库 RPM

复制代码
复制代码
复制代码
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm

TencentOS 3.3 有时不会生成 .repo文件,下一步手动补写仓库配置


三、手动创建 PostgreSQL 18 YUM 仓库(关键步骤)

复制代码
复制代码
复制代码
sudo tee /etc/yum.repos.d/pgdg18.repo > /dev/null << 'EOF'
[pgdg18]
name=PostgreSQL 18 for RHEL 8 - x86_64
baseurl=https://download.postgresql.org/pub/repos/yum/18/redhat/rhel-8-x86_64
enabled=1
gpgcheck=1
gpgkey=https://download.postgresql.org/pub/repos/yum/RPM-GPG-KEY-PGDG
module_hotfixes=1
EOF

刷新缓存:

复制代码
复制代码
复制代码
sudo yum clean all
sudo yum makecache

验证仓库可用:

复制代码
复制代码
复制代码
yum repolist enabled | grep pgdg
# 应看到 pgdg18

四、安装 PostgreSQL 18(跳过 GPG 校验防 404)

复制代码
复制代码
复制代码
sudo yum install -y postgresql18-server postgresql18 --nogpgcheck

✅ 成功标志:

复制代码
复制代码
复制代码
Installed:
  postgresql18-18.4-2PGDG.rhel8.10.x86_64
  postgresql18-libs-18.4-2PGDG.rhel8.10.x86_64
  postgresql18-server-18.4-2PGDG.rhel8.10.x86_64
Complete!

五、初始化数据库

复制代码
复制代码
复制代码
sudo /usr/pgsql-18/bin/postgresql-18-setup initdb

✅ 期望输出:

复制代码
复制代码
复制代码
Initializing database ... OK

六、启动并设置开机自启

复制代码
复制代码
复制代码
sudo systemctl enable postgresql-18
sudo systemctl start postgresql-18
sudo systemctl status postgresql-18

✅ 应看到:active (running)


七、验证安装

复制代码
复制代码
复制代码
psql --version
# psql (PostgreSQL) 18.x

八、基础使用(首次登录)

复制代码
复制代码
复制代码
su - postgres
psql

示例建库:

复制代码
复制代码
复制代码
CREATE DATABASE testdb;
\q
exit

九、开启远程访问(可选 / 生产建议收紧)

1️⃣ 修改监听地址

复制代码
复制代码
复制代码
sudo vi /var/lib/pgsql/18/data/postgresql.conf
复制代码
复制代码
复制代码
listen_addresses = '*'

2️⃣ 修改认证规则

复制代码
复制代码
复制代码
sudo vi /var/lib/pgsql/18/data/pg_hba.conf

追加:

复制代码
复制代码
复制代码
host  all  all  0.0.0.0/0  md5

3️⃣ 重启

复制代码
复制代码
复制代码
sudo systemctl restart postgresql-18

4️⃣ 防火墙 / 安全组

复制代码
复制代码
复制代码
sudo firewall-cmd --add-port=5432/tcp --permanent
sudo firewall-cmd --reload

👉 同时在腾讯云控制台 → 安全组放行 TCP 5432


十、常见问题速查

问题 原因 解决
404 repomd.xml TencentOS $releasever=3.3 手动写 pgdg18.repo(第三节)
No such file pgdg*.repo RPM 未生成 repo 按第三节手写
GPG key 404 云环境拉不到公钥 使用 --nogpgcheck
pip: command not found venv 未激活 source venv/bin/activate

✅ 一句话总结

TencentOS 3.3 用 EL8 仓库 → 手写 pgdg18.repo → --nogpgcheck 安装 → initdb → systemctl 启动

相关推荐
Nontee1 小时前
新手建表指南:数据库主键选自增ID还是UUID?
数据库·oracle
AI智图坊1 小时前
亚马逊多站点Listing视觉制作的效率瓶颈与AI解决方案:GPT-Image-2与Nano Banana Pro双模型分析
大数据·前端·数据库·人工智能·自动化·aigc
wanghao6664552 小时前
精益方法论:用更少的资源创造更大的价值
大数据·前端·数据库·敏捷开发
fQ9F9I58m2 小时前
Redis 分布式锁进阶第三百一十一篇
数据库·redis·分布式
无聊的老谢2 小时前
电信系统中的单元测试策略:构建高可靠性的微服务防线
数据库·微服务·单元测试
码不停蹄的玄黓2 小时前
MySQL 慢查询日志 核心参数详解
数据库·mysql
音乐宝贝家2 小时前
户外演出时吉他实际音量、音质等表现数据究竟如何?
数据库·新媒体运营·媒体·材质·内容运营
iiiiyu2 小时前
IO流相关编程题
java·大数据·开发语言·数据结构·数据库·mysql