PostgreSQL自带的命令行工具10- pg_basebackup

PostgreSQL自带的命令行工具10- pg_basebackup```bash

基础信息
OS版本:Red Hat Enterprise Linux Server release 7.9 (Maipo)
DB版本:16.2
pg软件目录:/home/pg16/soft
pg数据目录:/home/pg16/data
端口:5777

pg_basebackup 是 PostgreSQL 中用于创建服务器的基本备份(即数据目录的完整备份)的命令行工具。它通过复制数据库集群的文件系统级数据来创建备份,包括数据库文件、配置文件和事务日志。pg_basebackup 提供了一种简单且安全的方式来创建数据库的备份,这对于灾难恢复和主从复制设置非常有用。

通过help查看帮助文档。

[pg16@test backup]$ pg_basebackup --help
pg_basebackup takes a base backup of a running PostgreSQL server.

Usage:
  pg_basebackup [OPTION]...

Options controlling the output:
  -D, --pgdata=DIRECTORY receive base backup into directory
  -F, --format=p|t       output format (plain (default), tar)
  -r, --max-rate=RATE    maximum transfer rate to transfer data directory
                         (in kB/s, or use suffix "k" or "M")
  -R, --write-recovery-conf
                         write configuration for replication
  -t, --target=TARGET[:DETAIL]
                         backup target (if other than client)
  -T, --tablespace-mapping=OLDDIR=NEWDIR
                         relocate tablespace in OLDDIR to NEWDIR
      --waldir=WALDIR    location for the write-ahead log directory
  -X, --wal-method=none|fetch|stream
                         include required WAL files with specified method
  -z, --gzip             compress tar output
  -Z, --compress=[{client|server}-]METHOD[:DETAIL]
                         compress on client or server as specified
  -Z, --compress=none    do not compress tar output

General options:
  -c, --checkpoint=fast|spread
                         set fast or spread checkpointing
  -C, --create-slot      create replication slot
  -l, --label=LABEL      set backup label
  -n, --no-clean         do not clean up after errors
  -N, --no-sync          do not wait for changes to be written safely to disk
  -P, --progress         show progress information
  -S, --slot=SLOTNAME    replication slot to use
  -v, --verbose          output verbose messages
  -V, --version          output version information, then exit
      --manifest-checksums=SHA{224,256,384,512}|CRC32C|NONE
                         use algorithm for manifest checksums
      --manifest-force-encode
                         hex encode all file names in manifest
      --no-estimate-size do not estimate backup size in server side
      --no-manifest      suppress generation of backup manifest
      --no-slot          prevent creation of temporary replication slot
      --no-verify-checksums
                         do not verify checksums
  -?, --help             show this help, then exit

Connection options:
  -d, --dbname=CONNSTR   connection string
  -h, --host=HOSTNAME    database server host or socket directory
  -p, --port=PORT        database server port number
  -s, --status-interval=INTERVAL
                         time between status packets sent to server (in seconds)
  -U, --username=NAME    connect as specified database user
  -w, --no-password      never prompt for password
  -W, --password         force password prompt (should happen automatically)

Report bugs to <pgsql-bugs@lists.postgresql.org>.
PostgreSQL home page: <https://www.postgresql.org/>

基本用法

pg_basebackup [选项]...

常用选项

  • -D, --pgdata=目录:指定备份的目标目录,备份数据将存储在这里。
  • -F, --format=p|t:指定输出格式。p 表示纯文件系统(默认),t 表示 tar 格式。
  • -X, --wal-method=none|fetch|stream:指定事务日志(WAL)的包含方式。none 不包括 WAL 文件,fetch 在备份结束时获取 WAL 文件,stream 在进行备份的同时流式传输 WAL 文件。
  • -Z, --gzip:当使用 tar 格式时,开启这个选项将压缩输出文件。
  • -P, --progress:显示备份过程中的进度信息。
  • -v, --verbose:显示详细的输出信息。
  • -h, --host=主机名:数据库服务器的主机名或 IP 地址。
  • -p, --port=端口号:数据库服务器的端口。
  • -U, --username=用户名:连接数据库服务器的用户名。
  • -W, --password:提示输入连接数据库的密码。

示例

创建名为 /home/pg16/backup/test1 的目录里的数据库备份:

--执行备份
[pg16@test test1]$ pg_basebackup -D /home/pg16/backup/test1 -Fp -X stream -P -v
pg_basebackup: initiating base backup, waiting for checkpoint to complete
pg_basebackup: checkpoint completed
pg_basebackup: write-ahead log start point: 0/24000028 on timeline 1
pg_basebackup: starting background WAL receiver
pg_basebackup: created temporary replication slot "pg_basebackup_124716"
48265/48265 kB (100%), 2/2 tablespaces                                         
pg_basebackup: write-ahead log end point: 0/24000100
pg_basebackup: waiting for background process to finish streaming ...
pg_basebackup: syncing data to disk ...
pg_basebackup: renaming backup_manifest.tmp to backup_manifest
pg_basebackup: base backup completed

--确认
[pg16@test test1]$ pwd
/home/pg16/backup/test1
[pg16@test test1]$ ll
total 340
-rw------- 1 pg16 pg16    227 May  5 02:17 backup_label
-rw------- 1 pg16 pg16 274962 May  5 02:17 backup_manifest
drwx------ 8 pg16 pg16     72 May  5 02:17 base
-rw------- 1 pg16 pg16     44 May  5 02:17 current_logfiles
drwx------ 2 pg16 pg16   4096 May  5 02:17 global
drwx------ 2 pg16 pg16   4096 May  5 02:17 log
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_commit_ts
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_dynshmem
-rw------- 1 pg16 pg16   5740 May  5 02:17 pg_hba.conf
-rw------- 1 pg16 pg16   2640 May  5 02:17 pg_ident.conf
drwx------ 4 pg16 pg16     68 May  5 02:17 pg_logical
drwx------ 4 pg16 pg16     36 May  5 02:17 pg_multixact
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_notify
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_replslot
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_serial
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_snapshots
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_stat
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_stat_tmp
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_subtrans
drwx------ 2 pg16 pg16     19 May  5 02:17 pg_tblspc
drwx------ 2 pg16 pg16      6 May  5 02:17 pg_twophase
-rw------- 1 pg16 pg16      3 May  5 02:17 PG_VERSION
drwx------ 3 pg16 pg16     60 May  5 02:17 pg_wal
drwx------ 2 pg16 pg16     18 May  5 02:17 pg_xact
-rw------- 1 pg16 pg16    136 May  5 02:17 postgresql.auto.conf
-rw------- 1 pg16 pg16  29928 May  5 02:17 postgresql.conf

这个命令创建一个文件系统格式的备份,同时流式传输 WAL 文件以确保备份的一致性,展示备份进度,并提供详细输出。

注意事项

  • 在执行 pg_basebackup 前,确保目标备份目录存在且 PostgreSQL 用户有足够的权限写入该目录。
  • 备份期间,源数据库可以继续正常服务,pg_basebackup 命令实现了热备份。
  • WAL 文件的包含对于备份的恢复是非常重要的。如果选择 stream 方式,可以确保在恢复时不会丢失任何数据。
  • 考虑到安全和资源使用,合理选择备份方式和时间对生产环境尤其重要。

pg_basebackup 提供了一个直接且高效的方式来创建 PostgreSQL 数据库的全备份。对于数据库的灾难恢复规划以及主从复制架构的初始化,这是一个非常实用的工具。

谨记:心存敬畏,行有所止。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C补充1—1章1.0—C程序语言设计(许宝文,李志)

二手书到了&#xff0c;好消息&#xff0c;前主人看的很认真&#xff0c;坏消息&#xff0c;只看到这页了 啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊最后几题好难啊啊啊啊啊&#xff0c;再议 目录 1.1 入门 1.2 变量与算数表达式 练习1-3 //打印温度对照表 练习1-4 //摄氏-华氏温…

古墓丽影年度版喜加一 亚马逊免费游戏领取教程+下载安装教程

最近我们的老朋友亚马逊平台又为玩家们带来了一款免费的3A大作&#xff0c;这款游戏作为古墓丽影的续作在全球范围内都有着很高的热度和评价。但是许多玩家不知道这款游戏该如何领取&#xff0c;下面小编就为大家带来详细教程。 在领取之前&#xff0c;我们一定要优化我们的网…

【Js逆向】某博反爬机制的逆向分析

相信很多接触过爬虫的师傅&#xff0c;在对某博进行请求的时候&#xff0c;发现某博是会对cookie校验的&#xff0c;而我们在模拟操作的时候&#xff0c;是直接把浏览器的cookie进行copy&#xff0c;虽然我没有测试过这个cookie的有效期&#xff0c;但我觉得这样只适合日常测试…

LNMP一键安装包

LNMP一键安装包是什么? LNMP一键安装包是一个用Linux Shell编写的可以为CentOS/RHEL/Fedora/Debian/Ubuntu/Raspbian/Deepin/Alibaba/Amazon/Mint/Oracle/Rocky/Alma/Kali/UOS/银河麒麟/openEuler/Anolis OS Linux VPS或独立主机安装LNMP(Nginx/MySQL/PHP)、LNMPA(Nginx/MySQ…

亚马逊云科技产品测评:玩转云服务器(EC2)

文章目录 &#x1f4d1;引言一、亚马逊发展历史介绍二、云服务器资源地域分布三、云服务器实例规格四、EC2计费模式五、亚马逊免费EC2领取 &#x1f4d1;引言 亚马逊&#xff1a;世界上最大的云服务器提供商 亚马逊云科技 是由亚马逊公司提供的一系列云计算服务。它提供了弹性计…

KNOWLEDGE DISTILLATION BASED ON TRANSFORMED TEACHER MATCHING

摘要 温度标度作为logit匹配和概率分布匹配的bridge技术&#xff0c;在知识蒸馏&#xff08;KD&#xff09;中起着至关重要的作用。传统上&#xff0c;在蒸馏中&#xff0c;温度标度适用于教师的logits和学生的logits。在本文中&#xff0c;受到最近一些研究成果的启发&#x…

Leetcode—622. 设计循环队列【中等】

2024每日刷题&#xff08;128&#xff09; Leetcode—622. 设计循环队列 实现代码 class MyCircularQueue { public:MyCircularQueue(int k): q(k) {qSize k;}bool enQueue(int value) {if(isFull()) {return false;}q[rear] value;rear (rear 1) % qSize;deflag false;…

数据结构相关

数据结构相关 文章目录 数据结构相关[TOC](文章目录)前言一、数据结构介绍二、不同的逻辑结构的存储方案(Java实现)2.1 线性结构&#xff1a;线性表、数组2.2 线性结构&#xff1a;栈2.3 线性结构&#xff1a;队列2.4 树形结构&#xff1a;树 三、一些常见的3.1 布隆过滤器Bloo…

网络安全是否有需求

● 由于网络威胁数量不断增加&#xff0c;网络安全的需求很高。 ● 组织正在大力投资网络安全以保护其数据。 ● 就业市场缺乏熟练的网络安全专业人员。 ● 网络安全认证可以提升您在网络安全领域的职业前景。 ● 持续学习并了解最新的安全趋势在该领域至关重要。 网络安全重磅…

stm32f103zet6_串口实现-DHT11-tim1(定时)

1思路 1打开时钟 1.1使用定时器实现us级的计时 1.2在打开串口 1,3在DHT11驱动中修改引脚 stm32cudeMX 配置 1打开时钟 2打开串口 3打开tim1(定时器) 4生成代码 代码设置 1导入DHT11库(tim.h是定时器的文件系统自动生成的) DHT11.c #include "dht11.h" #inc…

鸿蒙内核源码分析(信号量篇) | 谁在负责解决任务的同步

基本概念 信号量&#xff08;Semaphore&#xff09; 是一种实现任务间通信的机制&#xff0c;可以实现任务间同步或共享资源的互斥访问。 一个信号量的数据结构中&#xff0c;通常有一个计数值&#xff0c;用于对有效资源数的计数&#xff0c;表示剩下的可被使用的共享资源数…

咖啡机定量出水的原理是什么

咖啡机实现定量出水的原理主要依赖于流量计的使用。流量计是一种能够测量液体或气体通过管道的速度和体积的装置。在咖啡机中&#xff0c;常用的小型流量计有霍尔式流量计和光电式流量计两种。 霍尔式流量计利用了霍尔效应的原理来实现流量测量。它包含一个带有两极磁铁的叶轮…

信创基础软件之操作系统

操作系统概述 操作系统是计算机系统软硬件资源的纽带。操作系统是连接硬件和数据库、中间件、应用软件的纽带&#xff0c;是承载各种信息设备和软件应用的重要基础软件。操作系统控制和管理整个计算机系统的硬件、软件资源&#xff0c;组织和调度计算机工作和资源&#xff0c;…

等保建设技术建议书(Word原件)

1信息系统详细设计方案 1.1安全建设需求分析 1.1.1网络结构安全 1.1.2边界安全风险与需求分析 1.1.3运维风险需求分析 1.1.4关键服务器管理风险分析 1.1.5关键服务器用户操作管理风险分析 1.1.6数据库敏感数据运维风险分析 1.1.7“人机”运维操作行为风险综合分析 1.2…

C语言结构体类型

C语言结构体类型 个人主页&#xff1a;大白的编程日记 个人主页&#xff1a;C语言学习之路 文章目录 C语言结构体类型前言一.结构体1.1结构体类型的声明1.2结构体变量的创建和初始化1.3结构成员访问操作符1.4结构的特殊声明1.5 结构的自引用 二.结构体内存对齐2.1对齐规则2.2内…

嵌入式linux学习第一天

参考正点原子Linux开发文档。记录下知识点。 Shell 基本操作 前面我们说 Shell 就是“敲命令”&#xff0c;那么既然是命令&#xff0c;那肯定是有格式的&#xff0c;Shell 命令的格式 如下&#xff1a; command -options [argument] command: Shell 命令名称。 options&…

27 JavaScript学习:异步编程

异步的概念 在JavaScript中&#xff0c;异步编程是一项重要的概念&#xff0c;特别在处理用户交互、网络请求和文件读写等场景下非常常见。JavaScript是一门单线程语言&#xff0c;因此需要通过异步编程来避免阻塞主线程&#xff0c;保证程序的流畅性和响应性。 在JavaScrip…

避雷!7.7分,新增1区TOP被标记On Hold,5本已被踢除!

本周投稿推荐 SSCI • 2/4区经管类&#xff0c;2.5-3.0&#xff08;录用率99%&#xff09; SCIE&#xff08;CCF推荐&#xff09; • 计算机类&#xff0c;2.0-3.0&#xff08;最快18天录用&#xff09; SCIE&#xff08;CCF-C类&#xff09; • IEEE旗下&#xff0c;1/2…

[入门] Unity Shader前置知识(5) —— 向量的运算

在Unity中&#xff0c;向量无处不在&#xff0c;我想很多人都使用过向量类的内置方法 normalized() 吧&#xff0c;我们都知道该方法是将其向量归一化从而作为一个方向与速度相乘&#xff0c;以达到角色朝任一方向移动时速度都相等的效果&#xff0c;但内部具体是如何将该向量进…

力扣每日一题109:有序链表转换二叉搜索树

题目 中等 给定一个单链表的头节点 head &#xff0c;其中的元素 按升序排序 &#xff0c;将其转换为 平衡 二叉搜索树。 示例 1: 输入: head [-10,-3,0,5,9] 输出: [0,-3,9,-10,null,5] 解释: 一个可能的答案是[0&#xff0c;-3,9&#xff0c;-10,null,5]&#xff0c;它…