当前位置: 首页 > article >正文

centos7搭建postgresql12主从

主从搭建

192.168.159.101 node1 主库(读写)
192.168.159.102 node2 备库(只读)
两台机器首先安装postgrsql

主库

postgres用户操作:

修改postgresql.conf

# 在文件中修改(此配置仅用于远程访问, 流复制后续还有额外配置):
listen_addresses = '*'
port = 15432
max_connections = 1500       # 最大连接数,据说从机需要大于或等于该值
wal_level = replica
max_wal_senders = 2   		#最多有2个流复制连接
wal_keep_segments = 16  	
wal_sender_timeout = 60s	#流复制超时时间

# 开启归档
....

修改pg_hba.conf,添加如下:

# 追加
# replica为postgres用户
# XX.XX.XX.XX为从节点的完整IP,如果为网段配置就不是32了,md5为允许密码验证,trust为免密
# TYPE  DATABASE        USER            ADDRESS                 METHOD
host    replication     replica         192.168.159.102/32          trust
# 需要远程访问,记得加(还有一个监听,在后面配置)
# 0.0.0.0/0为任意IP
host    all             all             0.0.0.0/0               md5

root用户操作:

#授权
chown -R postgres:postgres /var/run/postgresql/
chown -R postgres:postgres /home/postgres/pgdata/

postgres用户操作:

#启动
pg_ctl start

创建流复制用户

#切换用户
su - postgres
# 连接pgsql
psql -h 192.168.159.101 -p 15432
#执行sql
create role replica login replication encrypted password '123456';
SELECT rolname from pg_roles;

从库

root用户操作

chown -R postgres:postgres /var/run/postgresql/
chown -R postgres:postgres /home/postgres/pgdata/

从主库复制数据文件到本地

# 先清空原有数据文件(如非空)
rm -rf /home/postgres/pgdata/*
# 执行复制,ip为主库ip
pg_basebackup -h 192.168.159.101 -p 15432 -U replica -Fp -Xs -Pv -R -D /home/postgres/pgdata

# 输入主库中创建的replica用户密码后,开始同步

在这里插入图片描述

更改/home/postgres/pgdata目录权限为700

chmod -R 700 /home/postgres/pgdata/

postgres用户操作:

#启动
pg_ctl start

验证:

主库执行:

# 查看当前复制会话
select * from pg_stat_replication;

在这里插入图片描述

#如果返回t说明是备库,返回f说明是主库
select pg_is_in_recovery();

在这里插入图片描述

从库执行:

在这里插入图片描述

主库创建表:

CREATE TABLE "user" (
  "id" int4 NOT NULL,
  "name" varchar(255) COLLATE "pg_catalog"."default",
  "age" int4
);

查看从库:

在这里插入图片描述


http://www.kler.cn/a/597468.html

相关文章:

  • [贪心算法]最长回文串 增减字符串匹配 分发饼干
  • S32K144入门笔记(十七):PDB的API函数解读
  • C++20 中线程管理与取消机制的深度剖析
  • C++ 面向对象程序设计 - 学习笔记(持续更新中)
  • 第十三章 : Names in Templates_《C++ Templates》notes
  • debian安装Open5GS
  • 场外个股期权是什么?场外个股期权还能做吗?
  • 论文阅读:2023 arxiv Provable Robust Watermarking for AI-Generated Text
  • SpringBoot+Spring AI Alibaba接入RAG应用实践笔记
  • 【Golang】slice切片
  • python-selenium 爬虫 由易到难
  • Java之网络编程
  • ffmpeg+ubuntu16.04编译ffmpeg库
  • 自然语言处理(5)—— 中文分词
  • AF3 quat_to_rot函数解读
  • 手机号登录与高并发思考
  • C#实现高性能文件批量处理器(多线程+Hash校验+正则过滤)
  • 时序分析笔记
  • Java多线程与高并发专题——Future 是什么?
  • 【记录】并行运行olmocr把服务器跑崩