前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PostgreSql 14 主从负载均衡部署

PostgreSql 14 主从负载均衡部署

原创
作者头像
星哥玩云
发布2022-06-06 19:48:16
3.2K1
发布2022-06-06 19:48:16
举报
文章被收录于专栏:开源部署开源部署

前言

前些天给个环境部署PostgreSQL 主从负载均衡,这里仅仅简单记录一下命令以备后续使用,至于数据库的更多配置请自行根据需求配置.

版本环境

  • 服务器系统: CentOS 7.9
  • PostgreSQL 版本: 14
  • 主数据库内网 IP : 10.0.0.2
  • 从数据库内网 IP : 10.0.0.3

主数据库 10.0.0.2

安装

代码语言:javascript
复制
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
sudo yum install -y postgresql14-server
## 主库初始化数据库
/usr/pgsql-14/bin/postgresql-14-setup initdb
## 启动
sudo systemctl enable postgresql-14
sudo systemctl start postgresql-14

初始化

代码语言:javascript
复制
su - postgres
psql
## 创建 postgres 密码
ALTER USER postgres WITH PASSWORD '123456';
# #创建 从库 replica 用户密码
CREATE ROLE replica login replication encrypted password 'replica';
## 检查账号
SELECT usename from pg_user;
# 结果如下

# usename
# ----------
# postgres
# replica
# (2 rows)

# 查看权限
SELECT rolname from pg_roles;
# 结果如下

# rolname
# ----------
# postgres
# replica
# (2 rows)

# 退出
\q
exit

配置

pg_hba.conf
代码语言:javascript
复制
vi /var/lib/pgsql/14/data/pg_hba.conf
## 添加从库网段
host    all             all             0.0.0.0/0               trust
# replication privilege.
local   replication     all                                     peer
host    replication     replica            10.0.0.3/24        md5

注意此处 10.0.0.3/24 需修改为从库的 IP 段

postgresql.conf
代码语言:javascript
复制
vi /var/lib/pgsql/14/data/postgresql.conf
listen_addresses = '*'
wal_level = hot_standby
synchronous_commit = remote_write
# synchronous_commit 参考文档可选其他 on
max_wal_senders = 32     #同步最大的进程数量
wal_sender_timeout = 60s #流复制主机发送数据的超时时间
max_connections = 100    #最大连接数,从库的max_connections必须要大于主库的

从数据库 10.0.0.3

安装

代码语言:javascript
复制
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
sudo yum install -y postgresql14-server
## 从主库同步数据
pg_basebackup -D /var/lib/pgsql/14/data -h 10.0.0.2 -p 5432 -U replica -X stream -P

注意从库无需上文主库安装流程中的初始化步骤,修改上述 10.0.0.2 为主库 IP 地址来同步数据库.

配置

postgresql.conf

从 PostgreSQL 12 开始已经移除了 recovery.conf 文件,相关配置合并到了 postgresql.conf 中,由于从主库同步数据库,其中配置也需要移除和修改.

代码语言:javascript
复制
vi /var/lib/pgsql/14/data/postgresql.conf
## 移除或注释 wal_level
wal_level = xxx
## 修改或添加以下
primary_conninfo = 'host=10.0.0.2 port=5432 user=replica password=replica'
recovery_target_timeline = 'latest'
创建 standby.signal

创建 standby.signal 文件,声明从库.

代码语言:javascript
复制
vi /var/lib/pgsql/14/data/standby.signal
standby_mode = on
## 声明从库
权限

此处是踩坑过几次.

代码语言:javascript
复制
chown -R postgres.postgres /var/lib/pgsql/14/data

启动

代码语言:javascript
复制
sudo systemctl enable postgresql-14
sudo systemctl start postgresql-14

测试同步

主数据库 10.0.0.2

代码语言:javascript
复制
ps aux |grep sender
# 返回 postgres: walsender replica 10.0.0.2(56192) streaming 0/7000148

su - postgres
psql

select application_name, state, sync_priority, sync_state from pg_stat_replication;
# 返回 async
select pid,state,client_addr,sync_priority,sync_state from pg_stat_replication;
# 返回 async

从数据库 10.0.0.3

代码语言:javascript
复制
ps aux |grep receiver
# 返回 postgres: walreceiver streaming 0/7000148

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 版本环境
  • 主数据库 10.0.0.2
    • 安装
      • 初始化
        • 配置
          • pg_hba.conf
          • postgresql.conf
      • 从数据库 10.0.0.3
        • 安装
          • 配置
            • postgresql.conf
            • 创建 standby.signal
            • 权限
          • 启动
          • 测试同步
            • 主数据库 10.0.0.2
              • 从数据库 10.0.0.3
              相关产品与服务
              数据库
              云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档