PostgreSQL 双机热备 部署 Linux

2024-09-03 20:58

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

       数据库库往往会允许存在一个与主库同步的在线数据库服务器。当主数据库出现故障的时候,备库可以快速提升为主数据并且提供服务,实现数据库服务的高可用。

    如果备份数据库在接收数据库同步数据的时候,不能提供查询功能,称为warm standby server

    如果备份数据库在接收数据库同步数据的时候,能够提供查询功能,称为hot standby server

基于时间点恢复(PITR)的原理:

    Postgresql 中在数据目录下存在一个 pg_xlog ( pg10 中已经进行了更改 ) 始终维护这一个 WAL 日志文件,这个日志文件可以记录数据库文件的每次改变。

    可以在数据库异常崩溃之后,通过重放最后一次的 checkpoint 点之后的日志文件,把数据库推到一致的状态。不停的重放WAL日志就可以把数据库推到备份结束后的任一个时间点,这就是基于时间点的备份(PITR)。

    使用简单的 cp 命令把整个数据库给在线拷贝过来的备份叫做 基础备份。

    后续WAL日志的备份与此基础备份构成一个完整备份。

    把基础备份恢复到另一台机器,然后不停的从原始数据库机器上接收 WAL 日志,在新机器上持续重放 WAL 日志。

    这样就可以在任意时间内的另一台机器上打开这个新产生的数据库,他拥有当前数据库的最新状态。这台新机器上的数据库被称为Standby数据库

    把 WAL 日志传输到另一台机器上的方式有两种。

  •      WAL 日志归档

            其实就是把在线的 WAL 日志备份出来,在 Postgresql 中配置归档的方法是配置 archive_command

  •      流复制

           使用流复制的时候,只要主库一产生日志,就会立马传递到备库。

          流复制传递日志的方式有两种:

  1.    同步流复制
  2.    异步流复制   

           同步流复制,会在同步成功之后,数据库的事务才会完成。

           异步流复制,备库会比主库落后几秒的时间

 

 

 

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



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

相关文章

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom

如何在本地部署 DeepSeek Janus Pro 文生图大模型

《如何在本地部署DeepSeekJanusPro文生图大模型》DeepSeekJanusPro模型在本地成功部署,支持图片理解和文生图功能,通过Gradio界面进行交互,展示了其强大的多模态处... 目录什么是 Janus Pro1. 安装 conda2. 创建 python 虚拟环境3. 克隆 janus

本地私有化部署DeepSeek模型的详细教程

《本地私有化部署DeepSeek模型的详细教程》DeepSeek模型是一种强大的语言模型,本地私有化部署可以让用户在自己的环境中安全、高效地使用该模型,避免数据传输到外部带来的安全风险,同时也能根据自... 目录一、引言二、环境准备(一)硬件要求(二)软件要求(三)创建虚拟环境三、安装依赖库四、获取 Dee

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

Linux部署jar包过程

《Linux部署jar包过程》文章介绍了在Linux系统上部署Java(jar)包时需要注意的几个关键点,包括统一JDK版本、添加打包插件、修改数据库密码以及正确执行jar包的方法... 目录linux部署jar包1.统一jdk版本2.打包插件依赖3.修改密码4.执行jar包总结Linux部署jar包部署

deepseek本地部署使用步骤详解

《deepseek本地部署使用步骤详解》DeepSeek是一个开源的深度学习模型,支持自然语言处理和推荐系统,本地部署步骤包括克隆仓库、创建虚拟环境、安装依赖、配置模型和数据、启动服务、调试与优化以及... 目录环境要求部署步骤1. 克隆 DeepSeek 仓库2. 创建虚拟环境3. 安装依赖4. 配置模型

DeepSeek模型本地部署的详细教程

《DeepSeek模型本地部署的详细教程》DeepSeek作为一款开源且性能强大的大语言模型,提供了灵活的本地部署方案,让用户能够在本地环境中高效运行模型,同时保护数据隐私,在本地成功部署DeepSe... 目录一、环境准备(一)硬件需求(二)软件依赖二、安装Ollama三、下载并部署DeepSeek模型选