广告
返回顶部
首页 > 资讯 > 数据库 >PostgreSQL 12搭建流复制的过程是什么
  • 897
分享到

PostgreSQL 12搭建流复制的过程是什么

2024-04-02 19:04:59 897人浏览 独家记忆
摘要

本篇内容主要讲解“postgresql 12搭建流复制的过程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Postgresql 12搭建流复制的过程是什么

本篇内容主要讲解“postgresql 12搭建流复制的过程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Postgresql 12搭建流复制的过程是什么”吧!

主库
创建复制用户

[pg12@localhost pg120db]$ psql -c "CREATE USER replicator WITH REPLICATioN ENCRYPTED PASSWord 'test'" -d testdb
Timing is on.
Expanded display is used automatically.
CREATE ROLE
Time: 30.796 ms

常规参数配置

[pg12@localhost pg120db]$ grep 'listen' postgresql.conf 
listen_addresses = '*'        # what IP address(es) to listen on;
pg12@localhost pg120db]$ grep 'replication' pg_hba.conf 
# DATABASE can be "all", "sameuser", "samerole", "replication", a
# keyword does not match "replication". Access to replication
# "all", "sameuser", "samerole" or "replication" makes the name lose
# Allow replication connections from localhost, by a user with the
# replication privilege.
local   replication     all                                     trust
host    replication     all             127.0.0.1/32            trust
host    replication     all             192.168.0.0/16          md5
host    replication     all             ::1/128                 trust
[pg12@localhost pg120db]$

重新加载配置参数

[pg12@localhost pg120db]$ psql -c "select pg_reload_conf()" -d testdb
Timing is on.
Expanded display is used automatically.
 pg_reload_conf 
----------------
 t
(1 row)
Time: 454.580 ms

确认该库为master主库

[pg12@localhost pg120db]$ psql -c "select pg_is_in_recovery()" -d testdb
Timing is on.
Expanded display is used automatically.
 pg_is_in_recovery 
-------------------
 f
(1 row)
Time: 23.530 ms
[pg12@localhost pg120db]$

备库
使用pg_basebackup执行主库备份

[pg12@localhost ~]$ pg_basebackup -h 192.168.26.28 -U replicator -p 5432 -D $PGDATA -Fp -Xs -P -R
Password: 
 426401/9113562 kB (4%), 0/1 tablespace

其中-Fp表示以plain格式数据,-Xs表示以stream方式包含所需的WAL文件,-P表示显示进度,-R表示为replication写配置信息。
备份完成,使用-R选项,在data目录下自动生成standby.signal“信号”文件(可手工使用touch命令生成)以及更新了postgresql.auto.conf文件,postgresql.auto.conf中写入了主库的连接信息(可手工添加primary_conninfo信息)。

[pg12@localhost ~]$ pg_basebackup -h 192.168.26.28 -U replicator -p 5432 -D $PGDATA -Fp -Xs -P -R
Password: 
9113571/9113571 kB (100%), 1/1 tablespace
[pg12@localhost ~]$ 
[pg12@localhost ~]$ cd $PGDATA
[pg12@localhost testdb]$ ls
backup_label      pg_commit_ts   pg_log        pg_replslot   pg_stat_tmp  PG_VERSION            postgresql.conf
base              pg_dynshmem    pg_logical    pg_serial     pg_subtrans  pg_wal                standby.signal
current_logfiles  pg_hba.conf    pg_multixact  pg_snapshots  pg_tblspc    pg_xact
global            pg_ident.conf  pg_notify     pg_stat       pg_twophase  postgresql.auto.conf
[pg12@localhost testdb]$ ll standby.signal 
-rw-------. 1 pg12 pg12 0 Nov 12 16:35 standby.signal
[pg12@localhost testdb]$ 
[pg12@localhost testdb]$ cat postgresql.auto.conf
# Do not edit this file manually!
# It will be overwritten by the ALTER SYSTEM command.
primary_conninfo = 'user=replicator password=test host=192.168.26.28 port=5432 sslmode=prefer sslcompression=0 gssencmode=prefer krbsrvname=postgres target_session_attrs=any'
[pg12@localhost testdb]$ 
[pg12@localhost testdb]$ grep 'primary_conninfo' postgresql.*
postgresql.auto.conf:primary_conninfo = 'user=replicator password=test host=192.168.26.28 port=5432 sslmode=prefer sslcompression=0 gssencmode=prefer krbsrvname=postgres target_session_attrs=any'
postgresql.conf:#primary_conninfo = ''            # connection string to sending server
[pg12@localhost testdb]$

在PG 11中,需要创建recovery.conf文件,在此文件中配置standby_mode和primary_conninfo参数,PG 12已不再需要该文件,改为standby.signal文件以及通过配置参数直接设置。

备库启动数据库,通过pg_is_in_recovery确认是否正常配置

[pg12@localhost testdb]$ pg_ctl -D $PGDATA start
waiting for server to start....2019-11-12 16:46:31.635 CST [20436] LOG:  starting PostgreSQL 12.0 on x86_64-pc-linux-gnu, compiled by GCc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-36), 64-bit
2019-11-12 16:46:31.636 CST [20436] LOG:  listening on IPv4 address "0.0.0.0", port 5432
2019-11-12 16:46:31.636 CST [20436] LOG:  listening on IPv6 address "::", port 5432
2019-11-12 16:46:31.638 CST [20436] LOG:  listening on Unix Socket "/tmp/.s.PGSQL.5432"
2019-11-12 16:46:31.750 CST [20436] LOG:  redirecting log output to logging collector process
2019-11-12 16:46:31.750 CST [20436] HINT:  Future log output will appear in directory "pg_log".
 done
server started
[pg12@localhost testdb]$ psql -c "select pg_is_in_recovery()" -d testdb
 pg_is_in_recovery 
-------------------
 t
(1 row)
[pg12@localhost testdb]$

完成搭建
通过pg_stat_replication可查询复制状态(异步复制)

[pg12@localhost pg120db]$ psql -x -c "select * from pg_stat_replication" -d testdb
Timing is on.
Expanded display is used automatically.
-[ RECORD 1 ]----+------------------------------
pid              | 4503
usesysid         | 155959
usename          | replicator
application_name | walreceiver
client_addr      | 192.168.26.25
client_hostname  | 
client_port      | 35172
backend_start    | 2019-11-12 16:46:31.000236+08
backend_xmin     | 
state            | streaming
sent_lsn         | 6/A3000148
write_lsn        | 6/A3000148
flush_lsn        | 6/A3000148
replay_lsn       | 6/A3000148
write_lag        | 
flush_lag        | 
replay_lag       | 
sync_priority    | 0
sync_state       | async
reply_time       | 2019-11-12 16:48:32.509887+08
Time: 149.682 ms
[pg12@localhost pg120db]$

到此,相信大家对“PostgreSQL 12搭建流复制的过程是什么”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: PostgreSQL 12搭建流复制的过程是什么

本文链接: https://www.lsjlt.com/news/63583.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PostgreSQL 12搭建流复制的过程是什么
    本篇内容主要讲解“PostgreSQL 12搭建流复制的过程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL 12搭建流复制的过程是什么...
    99+
    2022-10-18
  • PostgreSQL怎么搭建流复制
    本篇内容主要讲解“PostgreSQL怎么搭建流复制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL怎么搭建流复制”吧!PostgreSQL通...
    99+
    2022-10-18
  • 怎么搭建postgresql-pg简易异步流复制
    这篇文章主要讲解了“怎么搭建postgresql-pg简易异步流复制”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么搭建postgresql-pg简易异步...
    99+
    2022-10-18
  • GTID的复制的搭建过程
    1.什么是GTIDGTID(Global Transaction ID)是对于一个已提交事务的编号,并且是一个全局唯一的编号;GTID实际上是由UUID+TID组成的。其中UUID是一个MySQL实例的唯一...
    99+
    2022-10-18
  • MYSQL主主复制的搭建过程
    本篇内容主要讲解“MYSQL主主复制的搭建过程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MYSQL主主复制的搭建过程”吧!一、环境说明:IP主机名数据库名连...
    99+
    2022-10-18
  • MySQL 5.5 主主复制搭建过程是怎样的
    MySQL 5.5 主主复制搭建过程是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 --节点1 IP 19...
    99+
    2022-10-19
  • pycharm搭建项目流程是什么
    搭建项目流程如下:1. 下载和安装PyCharm:首先,你需要从PyCharm官方网站下载适合你操作系统的PyCharm版本,并按照...
    99+
    2023-09-23
    pycharm
  • springCloud项目搭建流程是什么
    本篇内容主要讲解“springCloud项目搭建流程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springCloud项目搭建流程是什么”吧!实现跨服务的远程调用(RestTemplat...
    99+
    2023-06-30
  • MySQL复制架构的搭建及配置过程
    目录一主多从复制架构多主复制架构级联复制架构多主与级联复制结合架构多主复制架构的搭建master1的配置master2的配置MySQL高可用的搭建一主多从复制架构 在实际应用场景中,...
    99+
    2022-11-13
  • 小程序搭建制作流程是怎样的?
      如今,小程序技术已经非常成熟,制作小程序的门槛也越来越低,因为市场上有一些完善稳定的小程序SaaS制作平台,功能几乎可以满足,不需要了解技术,根据拖动部件设计页面,可以生成小程序,可以快速发布操作。小程序搭建制作流程是怎么样的呢?我...
    99+
    2023-09-04
    微信小程序 小程序
  • PostgreSQL12同步流复制搭建及主备切换的方法是什么
    这篇文章主要介绍“PostgreSQL12同步流复制搭建及主备切换的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PostgreSQL12同步流复制搭建及主备切换的方法是什么”文章能帮助大...
    99+
    2023-07-05
  • 云服务器的搭建过程是什么
    云服务器(Cloud Storage)是一种使用虚拟化技术构建的服务器,它通过互联网连接计算机和其他设备,并通过虚拟化技术将所有资源统一管理。使用云服务器可以让人们通过互联网访问、使用云计算资源、管理虚拟服务器和应用程序,从而降低了IT管理...
    99+
    2023-10-26
    过程 服务器
  • 镜像服务器搭建的流程是什么
    1.选择合适的服务器:选择一台配置适当的忆 速云服务器,可以选择自己购买或租用云服务器。2.选择合适的操作系统:选择合适的操作系统,...
    99+
    2023-05-13
    镜像服务器 服务器
  • java项目框架搭建的流程是什么
    搭建Java项目框架的一般流程如下:1.需求分析:明确项目的功能和需求,根据需求来选择合适的框架。2.选择框架:根据需求和技术要求,...
    99+
    2023-10-11
    java
  • PostgreSQL中执行sql的流程是什么
    小编给大家分享一下PostgreSQL中执行sql的流程是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、SQL执行流程PG执行SQL的过程有以下几个步骤:第一步,根据输入的SQL语...
    99+
    2022-10-18
  • 个人web服务器搭建的流程是什么
    1. 选择服务器操作系统:可以选择Linux、Windows等操作系统,其中Linux操作系统比较常用。2. 安装服务器软件:根据所...
    99+
    2023-05-13
    个人web服务器 服务器
  • 云服务器的搭建过程是什么样的
    云服务器的搭建过程主要分为以下几个步骤: 选择云服务器提供商:你需要选择一家云服务器提供商,比如阿里云、腾讯云、华为云、AWS等。这些云服务商提供的服务器和技术支持可以帮助你搭建私有云或公有云环境。 购买主机:你需要准备好所需的物理服务...
    99+
    2023-10-26
    过程 服务器
  • PostgreSQL的查询处理过程是什么
    这篇文章主要讲解了“PostgreSQL的查询处理过程是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PostgreSQL的查询处理过程是什么”吧!一、...
    99+
    2022-10-18
  • PostgreSQL中GetSnapshotData的处理过程是什么
    这篇文章主要讲解了“PostgreSQL中GetSnapshotData的处理过程是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PostgreSQL中...
    99+
    2022-10-18
  • PostgreSQL启动恢复流程框架是怎么样的
    小编给大家分享一下PostgreSQL启动恢复流程框架是怎么样的,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!以上是“Postg...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作