pg数据库的热备

Pg数据库主从复制

前言:公司的一台服务器因为断电导致系统损坏,经过3天的抢修,将服务器和数据恢复。为了避免数据的丢失,先将数据备份,并进行高可用。

​ 采用技术:keepalived+pg

​ 后期并实现zabbix对pg的端口检测和好可用的检测

​ 实验环境:

​ pg主库: centos7.9:192.168.60.50

​ pg从库: centos7.9: 192.168.60.164

​ 实际生产是:

​ 一台Centos7.9 作为主库

​ 一台ubuntu20.04 作为从库

​ 以实验测试环境为主:

安装pg数据库

该实验docker为主,采用docker-compose安装

[root@localhost pg]# cat docker-compose.yml 
version: '3.7'
services:postgis:image: postgis/postgis:12-3.2 container_name: postgisrestart: alwaysenvironment:# POSTGRES_DB: postgresPOSTGRES_USER: postgresPOSTGRES_PASSWORD: 123456ALLOW_IP_RANGE: 0.0.0.0/0ports:- "5436:5432"volumes:- ./postgis/pg_data/data/:/var/lib/postgresql/data/  # 将本地 data 目录映射到容器内的 /var/lib/postgresql/data - /etc/localtime:/etc/localtime:ro

对挂载目录赋权限

useradd postgres
chown postgres:postgres  -R postgis/
chmod +x postgis/ -R

修改完切记要重启容器

创建主从复制用户(流复制)

root@d94353c96edf:/# psql -Upostgres 
psql (12.12 (Debian 12.12-1.pgdg110+1))
Type "help" for help.
postgres=#CREATE ROLE replica login replication encrypted password 'replica';

执行创建sql语句,第三列是上面创建的用于复制的用户名,第四列为从节点ip地址

CREATE ROLE replica login replication encrypted password 'replica';

修改./data/pg_hba.conf文件


允许从库IP可以通过repl用户连接主库
# local         DATABASE  USER  METHOD  [OPTIONS]host    replication     replica         192.168.60/164/24      md5

修改主库上的配置文件(postgresql.conf文件)

listen_addresses = '*'   #允许数据库监听所有IP地址,即可以通过任何网络接口连接。
archive_mode = on      #启用归档模式,允许数据库将 WAL(Write-Ahead Logging)日志文件存档。
archive_command = '/bin/date'    #只是将日期打印出来,取消了真正的归档。
wal_level = replica    #设置为 replica,表示开启了逻辑复制以支持热备。
max_wal_senders = 10    #设置能够连接到主服务器进行 WAL 复制的最大连接数。这是为了支持有多个从服务器的场景。
wal_keep_size = 1024    #设置 WAL 文件的保留大小,以兆字节(M)为单位。超过这个大小的日志文件将不会被删除,以便后续从备份中进行还原。
wal_sender_timeout = 60s #设置 WAL 发送者(主服务器)发送数据的超时时间,这里是60秒。
max_connections = 100    #设置数据库允许的最大连接数。在这里要注意,从库的最大连接数必须大于主库的连接数,确保从库可以处理主库发送的所有连接。
#退出容器,并重启
docker restart postgres

从库设置

启动从库先不要挂载目录

切记

进入到从库postgres的容器内配置流复制

 
docker exec -it postgis bash
#删除数据,并将主节点数据同步过来
rm -rf /var/lib/postgresql/data/*
#使用pg_basebackup命令备份主数据库中的数据
pg_basebackup -h 192.168.60.50 -p 5436 -U replica --password -X stream -Fp --progress -D /var/lib/postgresql/data/ -R;

#数据同步后容器会关闭。再启动即可 docker start postgres

将数据目录copy出来后在挂载目录

mkdir -p ./postgis/pg_data/cd ./postgis/pg_data/
docker cp postgis:/var/lib/postgresql/data/ ./

配置权限

useradd postgres
chown postgres:postgres  -R postgis/
chmod +x postgis/ -R

打开挂载目录在进行挂载

打开注释的挂载目录即可

修改从库的配置

#创建文件vi /var/lib/postgresql/data/standby.signal  添加下面这行内容声明从库
standby_mode = 'on'
#修改文件vi /var/lib/postgresql/data/postgresql.conf 修改以下配置
wal_level = replica   # 设置 WAL 日志的级别为 replica,表示开启逻辑复制以支持热备。
primary_conninfo = 'host=192.168.60.50 port=5236 user=replica password=replica'   # 配置主库ip地址以及端口号,以及用于复制的用户名和密码	
hot_standby = on                     # 在恢复期间允许查询。这是在流复制过程中,从库在进行 WAL 日志恢复的同时允许查询读取。
recovery_target_timeline = latest    # 设置恢复的目标时间线。在这里,设置为 latest 表示从库将一直尝试连接到主库的最新时间线上。
max_connections = 120  				#必须大于主节点的连接数。这确保从库可以处理主库发送的所有连接请求。
#重启从库

查看主从状态

#进入主节点容器,
docker exec -it postgis bash
[root@localhost data]# docker exec -it postgis bash
root@af2d730a2610:/# psql -U postgres
psql (12.12 (Debian 12.12-1.pgdg110+1))
Type "help" for help.postgres=# select client_addr,sync_state from pg_stat_replication;client_addr   | sync_state 
----------------+------------192.168.60.164 | async
(1 row)postgres=# 

在主库创建一个库

create database test;

从库查看

postgres=# .\lList of databasesName       |  Owner   | Encoding |  Collate   |   Ctype    |   Access privileges   
------------------+----------+----------+------------+------------+-----------------------postgres         | postgres | UTF8     | en_US.utf8 | en_US.utf8 | template0        | postgres | UTF8     | en_US.utf8 | en_US.utf8 | =c/postgres          +|          |          |            |            | postgres=CTc/postgrestemplate1        | postgres | UTF8     | en_US.utf8 | en_US.utf8 | =c/postgres          +|          |          |            |            | postgres=CTc/postgrestemplate_postgis | postgres | UTF8     | en_US.utf8 | en_US.utf8 | test             | postgres | UTF8     | en_US.utf8 | en_US.utf8 | 
(5 rows)postgres-# 

同步成功

下一阶段在生产迁移,并通过keepalived做到高可用

并且在zabbix进行数据库端口的监控

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/12290.shtml

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

相关文章

传说中的运维门户设计

在IT服务管理这片广阔天地中,运维门户如同一位技艺高超的魔术师,轻轻一挥手,便将纷繁复杂的运维世界化繁为简,编织成一张便捷高效、触手可及的网络。它不仅是ITSM系统中不可或缺的一环,更是连接用户与技术世界的桥梁&a…

Spring WebFlux:响应式编程

在软件开发领域,随着互联网应用的规模和复杂性不断增加,传统的编程模型逐渐暴露出一些局限性,尤其是在面对高并发、大规模数据流处理等场景时。为了应对这些挑战,响应式编程(Reactive Programming)应运而生…

Java字符串去除空格的方法

前言 在Java编程实践中,处理字符串中的空格是一项基本且频繁的操作。本文将深入探讨如何使用Java原生方法以及Apache Commons Lang库中的StringUtils类,全方位解决字符串去空格的需求,让你的代码更加健壮和高效。 1. Java原生方法 a. trim…

电商核心技术揭秘56:客户关系管理与忠诚度提升

相关系列文章 电商技术揭秘相关系列文章合集(1) 电商技术揭秘相关系列文章合集(2) 电商技术揭秘相关系列文章合集(3) 文章目录 引言客户关系管理(CRM)的重要性提升顾客体验数据驱…

AWS之云种类与云服务模式

云种类分为3种: 公有云:任何个人或者企业都可以通过注册的方式直接使用的云。(特点:使用简单;通过web界面快速购买。缺点:安全性低;使用资源是与其他用户共享。) 私有云&#xff1…

Intel HDSLB 高性能四层负载均衡器 — 快速入门和应用场景

目录 文章目录 目录前言与背景传统 LB 技术的局限性HDSLB 的特点和优势HDSLB 的性能参数基准性能数据对标竞品 HDSLB 的应用场景HDSLB 的发展前景参考文档 前言与背景 在云计算、SDN、NFV 高速发展并普遍落地的今天,随着上云业务的用户数量越来越多、数据中心的规模…

umi项目配置之项目构建时配置umirc.ts

对于 umi 中能使用的自定义配置,你可以使用项目根目录的 .umirc.ts 文件或者 config/config.ts,值得注意的是这两个文件功能一致,仅仅是存在目录不同,2 选 1 ,.umirc.ts 文件优先级较高 umi 的配置文件是一个正常的 n…

【vivado】 IBERT GT收发器误码率测试

一、前言 IBERT(Integrated Bit Error Ratio Tester),集成误码率测试仪。作为用户来说可以使用这个工具对自己设计的板子中的高速串行收发器进行简单测试,从而判断设计的接口是否有问题。因为这个工具是直接集成到FPGA上,这样一来直接使用这个工具来测试…

ubuntu下安装wireshark

1、安装wireshark 打开终端,输入安装命令 sudo apt-get install wireshark 2、启动 输入命令回车,一定要加上sudo sudo wireshark 3、看到有很多UDP、ARP、ICMP协议等的网络报文 4、以太网口抓取到的报文,列表属性分别为: 编号| 时…

STL----push,insert,empalce

push_back和emplace_back的区别 #include <iostream> #include <vector>using namespace std; class testDemo { public:testDemo(int n) :num(n) {cout << "构造函数" << endl;}testDemo(const testDemo& other) :num(other.num) {cou…

数据分析——对比思维、A/B test

对比分析 数据大小 &#xff1a;与中值、平均值、目标值、标准做对比数据波动&#xff1a;变异系数、方差、标准差数据趋势&#xff1a;时间维度和空间维度 其中 时间维度 横向比较&#xff08;连续7天每天的销售量&#xff09; 纵向比较&#xff08;同一时期不同品类对比&…

iframe父级元素高度百分比不生效

<iframe :src"iframeUrl" width"100%" height"100%" frameborder"0" /> 1、使用绝对定位&#xff1a;将 iframe 的父级元素设置为相对定位&#xff0c;并将 iframe 设置为绝对定位。这样&#xff0c;iframe 就可以根据父级元素…

实验十 智能手机互联网程序设计(微信程序方向)实验报告

实验目的和要求 完成以下页面设计。 二、实验步骤与结果&#xff08;给出对应的代码或运行结果截图&#xff09; Wxml <view class"container"> <view class"header"> <view class"logo"…

景源畅信:抖音小店比较冷门的品类分享?

在抖音小店的世界里&#xff0c;热门品类总是吸引着众多商家和消费者的目光。然而&#xff0c;就像星空中的繁星&#xff0c;虽不那么耀眼却依然存在的冷门品类同样值得我们关注。它们或许不似服装、美妆那样日进斗金&#xff0c;但正是这些小众市场的存在&#xff0c;为平台带…

Java面试之SpringCloud篇

Nacos有什么用&#xff1f; ①服务注册与发现 ②配置管理 Es为什么查询效率快&#xff1f; &#xff08;1&#xff09;首先&#xff0c;ES使用了倒排索引这种数据结构来快速查找文档。倒排索引是一种针对文本搜索而优化的数据结构&#xff0c;它将每个词与出现这个词的文档列…

Linux 服务器配置共享文件夹(NFS)

一、准备三台 linux 服务器 三台服务器: manger:172.16.11.178 ap1:172.16.11.179 ap2:172.16.11.180 /root/serverfiles/ 为共享目录 二、配置步骤 1、在服务端01的机器上安装nfs和rpcbind程序 yum -y install nfs* yum -y install rpcbind* 2、在安装完nfs以及rpcb…

基于IDEA快速创建一个SpringMVC项目并且配置Tomcat

1&#xff0c;打开IDEA&#xff0c;新建Maven项目【使用web模板创建】 使用社区版的同学创建普通的maven项目&#xff0c;并配置项目的webapp&#xff0c;详情可参考 快速创建一个SpringMVC项目&#xff08;IDEA&#xff09; 2&#xff0c;在main目录下创建Java和resource目录…

2024洗地机爆款榜单,哪个牌子洗地机值得买?助你轻松选对洗地机

随着现代生活节奏的加快&#xff0c;人们对于家庭清洁的需求也越来越高。家用洗地机作为一种高效清洁工具&#xff0c;能够帮助您轻松应对家庭地板的清洁问题&#xff0c;节省时间和精力。然而&#xff0c;在选择洗地机时&#xff0c;究竟哪个牌子的洗地机值得买呢&#xff1f;…

Protobuf(基本使用和IDA中的protobuf解包逆向识别和重新利用)

文章目录 安装protobuf 基本使用如何使用 .pb.cc&#xff08;实现文件&#xff09;和.pb.h&#xff08;头文件&#xff09;.pb.h&#xff08;头文件&#xff09;.pb.cc&#xff08;实现文件&#xff09; 生成的c和h文件ida中解包打包解题1. 定义.proto文件2. 生成Python代码3. …

SpringBoot版本问题,类文件具有错误的版本

项目场景&#xff1a; Spirng Boot 版本3.2.5 jdk 版本 1.8 问题描述 运行程序的时候报错&#xff0c;什么错误的版本&#xff0c;比如&#xff1a; java: 无法访问org.springframework.amqp.core.Binding 错误的类文件: /Maven/repository/org/springframework/amqp/spring…