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.mzph.cn/diannao/74207.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

嵌入式基础知识学习:SPI通信协议是什么?

SPI(Serial Peripheral Interface)是串行外设接口的缩写,是一种广泛应用于嵌入式系统的高速同步串行通信协议,由摩托罗拉公司于20世纪80年代提出。以下是其核心要点: 一、SPI的核心定义与特点 基本特性 全双工同步通信…

996引擎-接口测试:背包

996引擎-接口测试:背包 背包测试NPC参考资料背包测试NPC CONSTANT = require("Envir/QuestDiary/constant/CONSTANT.lua"); MsgUtil = require("Envir/QuestDiary/utils/996/MsgUtil.lua");

vulnhub靶场之【hack-me-please靶机】

前言 靶机:billu_b0x2靶机,IP地址为192.168.10.8 攻击:kali,IP地址为192.168.10.6 靶机和攻击机都采用VMware虚拟机,都采用桥接网卡模式 文章涉及的靶机及工具,都可以自行访问官网或者项目地址进行获取&…

机器学习——KNN模型评价

一、主要函数 sklearn.metrics.accuracy_score() 是 scikit-learn 中用于计算分类模型准确率的函数,适用于评估分类任务的整体性能。 1、核心功能 作用:计算模型预测的准确率,即正确分类的样本数占总样本数的比例。公式:Accurac…

美国国家数据浮标中心(NDBC)

No.大剑师精品GIS教程推荐0地图渲染基础- 【WebGL 教程】 - 【Canvas 教程】 - 【SVG 教程】 1Openlayers 【入门教程】 - 【源代码示例 300】 2Leaflet 【入门教程】 - 【源代码图文示例 150】 3MapboxGL【入门教程】 - 【源代码图文示例150】 4Cesium 【入门教程】…

Qt调用Miniconda的python方法

1、 Win 64环境下载及安装 Miniconda 首先下载Windows 版Miniconda,https://docs.conda.io/en/latest/miniconda.html或 https://repo.anaconda.com/miniconda/ 安装界面及选择如下图所示: 安装完python3.12版报错如下。 说明:python3.11版…

Unity 与 JavaScript 的通信交互:实现跨平台的双向通信

前言 在现代游戏开发和 Web 应用中,Unity 和 JavaScript 的结合越来越常见。Unity 是一个强大的跨平台游戏引擎,而 JavaScript 是 Web 开发的核心技术之一。通过 Unity 和 JavaScript 的通信交互,开发者可以实现从 Unity 到 Web 页面的功能扩…

汽车免拆诊断案例 | 2024 款路虎发现运动版车无法正常识别智能钥匙

故障现象  一辆2024款路虎发现运动版车,搭载2.0 L发动机,累计行驶里程约为5 000 km。车主反映,使用遥控器无法解锁车门,随后使用机械钥匙打开车门,踩下制动踏板,按压起动按钮,仪表盘提示“将智…

跟着StatQuest学知识06-CNN进行图像分类

目录 一、CNN特点 二、CNN应用于图像分类 (一)使用过滤器 (二)通过ReLU激活函数 (三)应用新的滤波器(池化) (四)输入 (五)输出…

OpenHarmony 开源鸿蒙北向开发——linux使用make交叉编译第三方库

这几天搞鸿蒙,需要编译一些第三方库到鸿蒙系统使用。 头疼死了,搞了一个多星期总算搞定了。 开贴记坑。 一、SDK下载 1.下载 在linux下使用命令 wget https://cidownload.openharmony.cn/version/Master_Version/OpenHarmony_5.1.0.54/20250313_02…

Selenium Web UI自动化测试:从入门到实战

引言 在当今快速迭代的软件开发周期中,自动化测试已成为保障产品质量、提升测试效率的核心手段之一。而针对Web应用的UI自动化测试,Selenium作为最流行的开源工具之一,凭借其跨浏览器、多语言支持(Python、Java、C#等&#xff09…

Java 大视界 -- Java 大数据中的数据隐私保护技术在多方数据协作中的应用(147)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

编程考古-安德斯·海尔斯伯格(Anders Hejlsberg)回答离开Borland的原因

安德斯海尔斯伯格(Anders Hejlsberg)是著名的编程语言和工具开发者,曾主导开发了 Turbo Pascal、Delphi(Borland 时期),以及加入微软后参与的 C# 和 TypeScript。关于他离开 Borland 的原因,可以…

西门子仿真实例位置

C:\Users\san\Documents\Siemens\Simatic\Simulation\Runtime\Persistence S7-PLCSIM Advanced V3.0 可以打开文件,删除重建

【数据库系统原理】Ch7 数据库应用设计与开发实例

目录 大纲7.1 需求描述与分析7.2 系统设计7.3 系统实现7.4 系统测试与维护 习题真题2024-102024-042023-102023-042022-10 大纲 7.1 需求描述与分析 熟悉需求描述与分析的方法,达到"领会"层次。 7.2 系统设计 熟悉根据需求的描述划分系统的功能模块,能够进行初步…

使用 Python 的turtle库绘制精美图形

在 Python 编程的世界里,turtle库是一个非常有趣且实用的工具,它为初学者和有经验的开发者提供了一个简单而直观的方式来进行图形绘制。本文将详细讲解如何使用turtle库绘制不同的图形,包括六边形、一个特定的多边形,以及一个由线…

基于linux平台的C语言入门教程(5)基本数据类型

文章目录 1. 什么是数据类型?2. C 语言的基本数据类型3. 数据类型的存储大小4. 示例代码代码解析:输出结果: 5. 常见问题问题 1:float 和 double 的区别是什么?问题 2:unsigned 类型可以存储负数吗&#xf…

Bellman_ford 算法——解决负权边最短路径问题

卡码网:94. 城市间货物运输 I 94. 城市间货物运输 I 题目描述 某国为促进城市间经济交流,决定对货物运输提供补贴。共有 n 个编号为 1 到 n 的城市,通过道路网络连接,网络中的道路仅允许从某个城市单向通行到另一个城市,不能反向通行。 网络中的道路都有各自的运输成本…

mysql——第二课

学生表 CREATE TABLE student (id int(11) NOT NULL AUTO_INCREMENT,name varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,sex varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,age int(11) DEFAULT NULL,c_id int(10) DEFAULT NULL,PRIMARY KEY (id),KEY c_id (c_id),CONSTR…

图解 ThreadLocal

在 Java 多线程编程的世界里,ThreadLocal 是一个非常实用的工具,它为每个线程提供了独立的变量副本,避免了多线程环境下的变量共享问题。今天,我们就从内存视角出发,通过一张图来深入理解 ThreadLocal 的工作原理&…