Linux 下部署 PostgreSQL的双机热备

2024-09-03 20:58

本文主要是介绍Linux 下部署 PostgreSQL的双机热备,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建备库的步骤主要可以分成两大步骤:

   生成基础备份

    把基础备份拷贝到备机上,配置 recovery.conf  把备库启动在 standby 模式下

  即可完成数据库的Standby库的搭建

Linux 下安装 PostgresSQL:

  解压数据库的安装源码 

      tar -zxvf postgresql.tar.gz

  移动数据库导安装位置

   mv  postgreql /home/osdba

  配置数据库安装

   ./configure --prefix=/home/osdba --without-readline

  编译安装包:

   make

   安装编译后的文件 

    make install

   添加 Linux 用户名:

    adduser  postgres

  修改 Linux 数据库用户密码passwd postgres

     mkdir /home/osdba/

    给postgres 用户赋予权限安装目录的权限

     chmod -R 755 postgres:postgres /home/osdba

   配置环境变量

     修改环境变量

      vi ~/.bash_profile

      添加环境变量中的 postgresql 的 bin 目录

      添加环境变量中的 postgresql 的 data 目录

     使环境变量生效   source

   初始化数据库

       initdb

    启动数据库

       pg_ctl start

  到目前为止,主库和备库的操作完全一样,这样我们可以看到两个数据库都能正常启动。

由于两台数据库需要进行数据通信来保障数据的一致性,所有还需要关闭防火墙,或者开放防火墙的端口,允许数据库进行数据交互。

主库修改postgresql.conf文件

      修改内容:

       listen_address = '*'

       wal_level = hot_standby

       checkpoint_timeout = 5min

       archive_mode = on

       archive_command = 'true'

      max_wal_senders = 2  

      wal_keep_segments = 16

      hot_standby = on

      max_standby_streaming_delay = 30s

      wal_receiver_status_internal = 1s

      hot_standby_feedback = on

      wal_receiver_timeout = 60s

修改pg_hba.conf

     IPV4 下

     host  all   all  0.0.0.0/0 trust

     replication privilege:

      host  replication postgres 0.0.0.0/0 trust

重启postgresql

     备库:

      停止备库服务   pg_ctl stop

      删除备库数据库文件夹

       rm -rf /home/osdba/data

     连接主库

      psql -h host -p port -U postgres -d postgres

     进行备份

      select pg_start_Backup('backuptag',true);

      进行拷贝

     scp --r postgres@主库IP:/home/osdba/data  /home/osdba/data

     停止主库备份

     select pg_stop_backup();

     修改recovery.conf文件

      standby_mode = on

       primary_conninfo = 'user=postgres password = 123456  host = 主库IP  port = 5432  sslnode = disable  sslcompression=1’

   启动备库

     pg_ctl start

   连接主库,创建表,添加数据,可以看到数据被同步到备库,备库只能查询不能新增。可以做到读写分离 

这篇关于Linux 下部署 PostgreSQL的双机热备的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134034

相关文章

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

jdk21下载、安装详细教程(Windows、Linux、macOS)

《jdk21下载、安装详细教程(Windows、Linux、macOS)》本文介绍了OpenJDK21的下载地址和安装步骤,包括Windows、Linux和macOS平台,下载后解压并设置环境变量,最... 目录1、官网2、下载openjdk3、安装4、验证1、官网官网地址:OpenJDK下载地址:Ar

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo