postgresql自带指令命令系列三

目录

简介

bin目录

28.pg_verifybackup

29.pg_waldump

30.postgres

31.postmaster -> postgres

32.psql

33.reindexdb

34.vacuumdb

35.vacuumlo 

总结:


简介

        在安装postgresql数据库的时候会需要设置一个关于postgresql数据库的PATH变量
export PATH=/home/postgres/pg/bin:$PATH,该变量会指向postgresql安装路径下的bin目录。这个安装目录和我们在进行编译的时候./configure --prefix= [指定安装目录]    中的prefix参数设置相关。--bindir=DIR  参数可以指定bin目录的具体存放路径。postgresql对应的PATH变量没有设置正确,会导致执行文件对应的命令无法使用

        本文使用postgresql-15.2版本进行讲解

bin目录


        进入到对应的bin目录中去,可以看到有以下的执行文件,本博主将进行一一讲解

clusterdb
createdb
createuser
dropdb
dropuser
ecpg
initdb
oid2name
pg_amcheck
pg_archivecleanup
pg_basebackup
pgbench
pg_checksums
pg_config
pg_controldata
pg_ctl
pg_dump
pg_dumpall
pg_isready
pg_receivewal
pg_recvlogical
pg_resetwal
pg_restore
pg_rewind
pg_test_fsync
pg_test_timing
pg_upgrade
pg_verifybackup
pg_waldump
postgres
postmaster -> postgres
psql
reindexdb
vacuumdb
vacuumlo

 接上文

28.pg_verifybackup

         pg_verifybackup — 验证PostgreSQL集群的基础备份的完整性,当我们做完备份之后,可以只用该工具对备份进行验证

[postgres@vm03 ~]$ pg_basebackup -Fp -P -v -D backup/
pg_basebackup: initiating base backup, waiting for checkpoint to complete
pg_basebackup: checkpoint completed
pg_basebackup: write-ahead log start point: 0/18000060 on timeline 1
pg_basebackup: starting background WAL receiver
pg_basebackup: created temporary replication slot "pg_basebackup_2554"
41785/41785 kB (100%), 1/1 tablespace                                         
pg_basebackup: write-ahead log end point: 0/18000138
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
[postgres@vm03 ~]$ 
[postgres@vm03 ~]$ pg_verifybackup    backup/
backup successfully verified

在实际完成数据库备份的时候,会生成backup_label,backup_manifest信息文件, pg_verifybackup会先读取backup_manifest文件的信息,然后验证备份文件目录的完整性,再接着基于读取backup_manifest文件的信息对备份文件下所有信息文件的效验。

[postgres@vm03 ~]$ cd backup/
[postgres@vm03 backup]$ ll
total 204
-rw------- 1 postgres postgres    227 Dec  9 18:34 backup_label
-rw------- 1 postgres postgres 141510 Dec  9 18:34 backup_manifest
drwx------ 5 postgres postgres     33 Dec  9 18:34 base
-rw------- 1 postgres postgres     44 Dec  9 18:34 current_logfiles
drwx------ 2 postgres postgres   4096 Dec  9 18:34 global
drwx------ 2 postgres postgres    246 Dec  9 18:34 log
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_commit_ts
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_dynshmem
-rw------- 1 postgres postgres   4774 Dec  9 18:34 pg_hba.conf
-rw------- 1 postgres postgres   1636 Dec  9 18:34 pg_ident.conf
drwx------ 4 postgres postgres     68 Dec  9 18:34 pg_logical
drwx------ 4 postgres postgres     36 Dec  9 18:34 pg_multixact
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_notify
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_replslot
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_serial
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_snapshots
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_stat
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_stat_tmp
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_subtrans
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_tblspc
drwx------ 2 postgres postgres      6 Dec  9 18:34 pg_twophase
-rw------- 1 postgres postgres      3 Dec  9 18:34 PG_VERSION
drwx------ 3 postgres postgres     60 Dec  9 18:34 pg_wal
drwx------ 2 postgres postgres     18 Dec  9 18:34 pg_xact
-rw------- 1 postgres postgres     88 Dec  9 18:34 postgresql.auto.conf
-rw------- 1 postgres postgres  29516 Dec  9 18:34 postgresql.conf
[postgres@vm03 backup]$ cat backup_label 
START WAL LOCATION: 0/18000060 (file 000000010000000000000018)
CHECKPOINT LOCATION: 0/18000098
BACKUP METHOD: streamed
BACKUP FROM: primary
START TIME: 2023-12-09 18:34:47 CST
LABEL: pg_basebackup base backup
START TIMELINE: 1


29.pg_waldump

        pg_waldump 是一个查看PostgreSQL 预写式日志的工具,常常用与PITR去读取对应时间点的LSN以进行PITR恢复        

[postgres@vm03 backup]$ cd pg_wal/
[postgres@vm03 pg_wal]$ ll
total 16384
-rw------- 1 postgres postgres 16777216 Dec  9 18:34 000000010000000000000018
drwx------ 2 postgres postgres        6 Dec  9 18:34 archive_status
[postgres@vm03 pg_wal]$ pg_waldump 000000010000000000000018 
rmgr: Standby     len (rec/tot):     50/    50, tx:          0, lsn: 0/18000028, prev 0/170001C0, desc: RUNNING_XACTS nextXid 91773 latestCompletedXid 91772 oldestRunningXid 91773
rmgr: Standby     len (rec/tot):     50/    50, tx:          0, lsn: 0/18000060, prev 0/18000028, desc: RUNNING_XACTS nextXid 91773 latestCompletedXid 91772 oldestRunningXid 91773
rmgr: XLOG        len (rec/tot):    114/   114, tx:          0, lsn: 0/18000098, prev 0/18000060, desc: CHECKPOINT_ONLINE redo 0/18000060; tli 1; prev tli 1; fpw true; xid 0:91773; oid 24610; multi 1; offset 0; oldest xid 716 in DB 1; oldest multi 1 in DB 1; oldest/newest commit timestamp xid: 0/0; oldest running xid 91773; online
rmgr: XLOG        len (rec/tot):     34/    34, tx:          0, lsn: 0/18000110, prev 0/18000098, desc: BACKUP_END 0/18000060
rmgr: XLOG        len (rec/tot):     24/    24, tx:          0, lsn: 0/18000138, prev 0/18000110, desc: SWITCH 


30.postgres

         这是一个非常重要的指令,常常再因为数据库运行故障时,会使用单用户模式进入数据库中进行排查。

[postgres@vm03 ~]$ postgres --singlePostgreSQL stand-alone backend 15.3
backend> 

 使用CTRL+D退出单用户模式

        该指令也可以启动数据库,实现后台运行

nohup postgres > nohup.out 2>&1 &
postgres   2893   2361  1 19:05 pts/0    00:00:00 postgres
postgres   2894   2893  0 19:05 ?        00:00:00 postgres: logger
postgres   2895   2893  0 19:05 ?        00:00:00 postgres: checkpointer
postgres   2896   2893  0 19:05 ?        00:00:00 postgres: background writer
postgres   2898   2893  0 19:05 ?        00:00:00 postgres: walwriter
postgres   2899   2893  0 19:05 ?        00:00:00 postgres: autovacuum launcher
postgres   2901   2893  0 19:05 ?        00:00:00 postgres: logical replication launcher
postgres   2905   2788  0 19:05 pts/3    00:00:00 ps -ef
postgres   2906   2788  0 19:05 pts/3    00:00:00 grep --color=auto postgres

        无论你使用pg_ctl start 还是postgres 启动数据库,都会拉起一个postgres进程。在使用pg_ctl start启动数据库的时候,其实也就是去调用postgres进行启动数据库。


31.postmaster -> postgres

         postmasterpostgres的一个废弃的别名,一直使用软连接挂载到postgres上。


32.psql

        这是一个进入postgresql数据库,在学习postgresql数据库非常常见的一个指令工具。


33.reindexdb

        这是一个重建数据库或者数据库表的指令工具。数据库在使用的时候常常由于位置情况导致,表的索引损坏的情况,此时可以使用该指令,对表的索引进行重建。

        创建测试数据。

CREATE TABLE test_table (id SERIAL PRIMARY KEY,name VARCHAR(200)
);CREATE INDEX idx_test_table_name ON test_table(name);INSERT INTO test_table (id ,name ) select id , md5(id::text)  from generate_series(2,80000) as id ;

查看索引所在地址, 

postgres=# select pg_relation_filepath('idx_test_table_name');pg_relation_filepath 
----------------------base/5/25105
(1 row)

删掉索引文件 

 rm -rf  $PGDATA/base/5/25105

 此时查询该表便会报错,提示索引文件缺失


postgres=# select  *  from test_table;
ERROR:  could not open file "base/5/25105": No such file or directory

使用 reindexdb对其进行修复

[postgres@vm03 ~]$ reindexdb -t test_table -i idx_test_table_name
[postgres@vm03 ~]$ 

此时再次查看文件变可以查看了

 


34.vacuumdb

        清理数据库中的死元组,并回收存储空间的工具,往往数据库正常启动状态下,会有autovacuum launcher 进程,会自动清理数据库的死元组信息,并更新统计信息,优化器会根据新的统计信息对数据的相关优化判断重新定义。

        vacuumdb简单理解,也就时vacuum的SQL命令的一个封装工具

[postgres@vm03 ~]$ vacuumdb -z 
vacuumdb: vacuuming database "postgre


35.vacuumlo 

        vacuumlo 是一个 "会" 从 PostgreSQL 数据库移除所有孤立的大对象的简单程序。

总结:

        本博主,根据在实际工作使用的频率,以及对于数据库故障处理,日常维护的重要性进行评星(满星五颗星)。

重要性指令作用
*****clusterdb重组或重新排序数据库表,以优化性能。
**createdb创建新的数据库。
****createuser创建新的数据库用户。
**dropdb 删除数据库。
****dropuser删除数据库用户。
**ecpg处理嵌入式 SQL。
**initdb初始化新的 PostgreSQL 数据库实例。
*****oid2name转换 OID(对象标识符)为名称。
***pg_amcheck检查 PostgreSQL 索引的一致性。
**pg_archivecleanup从归档目录中删除不再需要的 WAL 日志文件。
*****pg_basebackup创建 PostgreSQL 数据库的基础备份。
*****pgbench进行 PostgreSQL 数据库基准测试。
****pg_checksums校验和控制和修复数据文件。
****pg_config显示 PostgreSQL 的编译配置。
**pg_controldata显示 PostgreSQL 数据库控制信息。
****pg_ctl启动、停止、或重新加载 PostgreSQL 服务器。
*****pg_dump备份 PostgreSQL 数据库
*****pg_dumpall备份所有 PostgreSQL 数据库和角色
*pg_isready检查 PostgreSQL 服务器是否准备好接收连接。
**pg_receivewal接收 WAL 日志流并将其写入文件。
*pg_recvlogical接收逻辑复制流。
*****pg_resetwal重置 PostgreSQL 数据库的日志文件。
*****pg_restore恢复 PostgreSQL 数据库备份。
****pg_rewind数据库增量、全量备份工具,可用与PITR相关技术点
***pg_test_fsync测试文件同步方法的性能。
***pg_test_timing测试 PostgreSQL 服务器的计时器。
****pg_upgrade升级 PostgreSQL 数据库到新版本。
**pg_verifybackup验证 PostgreSQL 数据库备份的一致性。
****pg_waldump显示 PostgreSQL WAL 文件的内容。
***postgres PostgreSQL 服务器进程。
*postmaster PostgreSQL 主进程。
****psql PostgreSQL 的交互式终端。
*****reindexdb重新建立 PostgreSQL 数据库中的索引。
*****vacuumdb释放未使用的存储空间并优化数据库。
*vacuumlo释放未使用的大对象存储空间。

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

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

相关文章

Linux CentOS 7.6安装jdk1.8教程

安装教程 第一种方式(通过yum安装):第一步:输入查找命令:第二步:输入安装命令:第三步:安装完成,输入安装命令后,等到出现Complete!代表安装完成第…

PyTorch实现逻辑回归

最终效果 先看下最终效果: 这里用一条直线把二维平面上不同的点分开。 生成随机数据 #创建训练数据 x torch.rand(10,1)*10 #shape(10,1) y 2*x (5 torch.randn(10,1))#构建线性回归参数 w torch.randn((1))#随机初始化w,要用到自动梯度求导 b …

小米手机锁屏时间设置为永不休眠_手机不息屏_保持亮屏

环境:打开手机自带的锁屏时间设置发现没有 永不息屏的选项 原因:采用了三星OLED屏幕,所以根据OLED屏幕特性,这个是为了防止烧屏而特意设计的。非OLED机型支持设置“永不” 解决方案1:原生系统是支持永不锁屏的&#…

ES 如何将国际标准时间格式进行格式化与调整时区

需求,日志收集的时候,时间格式是国际标准时间格式。形如yyyy-MM-ddTHH:mm:ss.SSS。 (2023-12-05T02:45:50.282Z)这个时区也不对,那如何将此类型的时间,进行格式化呢? 本篇文章体统一个案例&…

Other -- ChatGPT 原理

本文为个人理解,帮助小白(本人就是)了解正在创建新时代的 AI 产品,如文中理解有误欢迎留言。 [参考链接--](https://baijiahao.baidu.com/s?id1765556782543603120&wfrspider&forpc) 1. 了解一些基本概念 大语言模型&a…

【面试】测试/测开(ING)

63. APP端特有的测试 参考:APP专项测试、APP应用测试 crash和anr的区别 1)网络测试 2)中断测试 3)安装、卸载测试 4)兼容测试 5)性能测试(耗电量、流量、内存、服务器端) 6&#xf…

画对比折线图【Python】

出这一期想必是我做某个课程作业遇到了。 由于去各个官网下载对比图要钱,我还是不想花钱的!真讨厌!浅浅水一期。 以下是要做的对比图的数据: 代码: from matplotlib import pyplot as plt#设置中文显示plt.rcParams[…

CSS新手入门笔记整理:CSS浮动布局

文档流概述 正常文档流 “文档流”指元素在页面中出现的先后顺序。正常文档流,又称为“普通文档流”或“普通流”,也就是W3C标准所说的“normal flow”。正常文档流,将一个页面从上到下分为一行一行,其中块元素独占一行&#xf…

ChatGPT OpenAI API请求限制 尝试解决

1. OpenAI API请求限制 Retrying langchain.chat_models.openai.ChatOpenAI.completion_with_retry.._completion_with_retry in 4.0 seconds as it raised RateLimitError: Rate limit reached for gpt-3.5-turbo-16k in organization org-U7I2eKpAo6xA7RUa2Nq307ae on reques…

让内存无处可逃:智能指针[C++11]

智能指针 文章目录 智能指针前言RAII什么是智能指针智能指针的应用示例 C98的auto_ptr共享型智能指针:shared_ptrshared_ptr的使用初始化获取原生指针指定删除器默认删除器default_delete指定删除器指定删除器管理动态数组 shared_ptr的伪实现shared_ptr的注意事项避…

【Docker】进阶之路:(五)Docker引擎

【Docker】进阶之路:(五)Docker引擎 Docker引擎简介Docker引擎的组件构成runccontainerd Docker引擎简介 Docker引擎是用来运行和管理容器的核心部分。Docker首次发布时,Docker 引擎由LXC 和 Docker daemon 两个核心组件构成。 …

linux驱动开发——内核调试技术

目录 一、前言 二、内核调试方法 2.1 内核调试概述 2.2 学会分析内核源程序 2.3调试方法介绍 三、内核打印函数 3.1内核镜像解压前的串口输出函数 3.2 内核镜像解压后的串口输出函数 3.3 内核打印函数 四、获取内核信息 4.1系统请求键 4.2 通过/proc 接口 4.3 通过…

算法:有效的括号(入栈出栈)

时间复杂度 O(n) 空间复杂度 O(n∣Σ∣),其中 Σ 表示字符集,本题中字符串只包含 6 种括号 /*** param {string} s* return {boolean}*/ var isValid function(s) {const map {"(":")","{":"}","["…

python格式化内容

1.字符串格式化: 定义列表 [{"姓名": "张三", "年龄": 18, "性别": "男"}, {"姓名": "里斯李四李斯", "年龄": 18, "性别": "男"}, {"姓名": "斯托夫斯基…

上位机与PLC:ModbusTCP通讯之数据类型转换

前请提要: 从PLC读取的数值,不管是读正负整数还是正负浮点数,读取过来后都会变成UInt16,也就是Ushort类型 一、ushort(UInt16)转成 Int32 源代码方法: //ushort类型转Int32类型的方法private int ushortToInt32(ushort[] date, int start){//先进行判断,长度是否正确…

模型评价指标

用训练好的模型结果进行预测,需要采用一些评价指标来进行评价,才可以得到最优的模型 常用的指标: 1.分类任务 ConfusionMatrix 混淆矩阵Accuracy 准确率Precision 精确率Recall 召回率F1 score H-mean值ROC Curve ROC曲线PR …

天池SQL训练营(三)-复杂查询方法-视图、子查询、函数等

-天池龙珠计划SQL训练营 SQL训练营页面地址:https://tianchi.aliyun.com/specials/promotion/aicampsql 3.1 视图 我们先来看一个查询语句(仅做示例,未提供相关数据) SELECT stu_name FROM view_students_info;单从表面上看起来…

rancher harvester deploy demo 【部署 harvester v1.2.1】

简介 Harvester 是一个现代的、开放的、可互操作的、基于Kubernetes的超融合基础设施(HCI)解决方案。它是一种开源替代方案,专为寻求云原生HCI解决方案的运营商而设计。Harvester运行在裸机服务器上,提供集成的虚拟化和分布式存储功能。除了传统的虚拟机…

SQL SELECT 语句

SELECT 语句用于从数据库中选取数据。 SQL SELECT 语句 SELECT 语句用于从数据库中选取数据。 结果被存储在一个结果表中,称为结果集。 SQL SELECT 语法 SELECT column1, column2, ... FROM table_name; 与 SELECT * FROM table_name; 参数说明: …

二分查找|双指针:LeetCode:2398.预算内的最多机器人数目

作者推荐 本文涉及的基础知识点 二分查找算法合集 滑动窗口 单调队列:计算最大值时,如果前面的数小,则必定被淘汰,前面的数早出队。 题目 你有 n 个机器人,给你两个下标从 0 开始的整数数组 chargeTimes 和 runnin…