PostgreSQL教程(9)逻辑备份工具pg_dump使用教程
一、PostgreSQL 逻辑备份介绍
PostgreSQL 原生支持的逻辑备份工具为pg_dump和pgdump_all。数据库逻辑备份的原理都相同,都是将数据以SQL语句的形式输出到一个文本文件,然后再将备份文件中的SQL语句进行回放的形式进行数据还原。在进行备份时会对当前数据库状态进行快照,然后基于快照来进行数据转储,避免因为备份而阻塞其他事务。换言之,在备份过程中发生的更新就不会被转储下来了。
pg_dump / pg_dumpall 区别如下:
· pg_dump:备份指定的数据库和对象,但是不包含角色、表空间等全局对象。备份时支持多种格式导出,如SQL脚本(默认)、目录格式、tar格式、pg_restore专用格式等。常用于单库迁移或临时备份部分schema、部分表
· pg_dump_all:通过内部调用pg_dump来对整个实例的所有对象进行备份,包括用户、角色、表空间,适合做全库迁移。因为备份的是整个数据库对象,包括角色和表空间,所以备份和恢复操作都需要使用管理员权限来完成。在日常运维中,更多使用它来备份全局的角色和表空间而不是数据
二、pg_dump 使用说明
1、pg_dump常用选项
-h:指定需要进行备份的数据库主机IP
-p:指定需要进行备份的数据库端口
-U:指定需要进行备份的数据库用户名
-W:以交互形式输入密码
-f:将备份输出到指定文件中
-F | --format:指定备份格式,默认为p,表示备份文件为SQL格式,该格式的备份文件可以使用导入的方式进行还原;c为二进制格式,只能使用pg_restore还原;d为备份到指定目录中,并且提供压缩;t为备份为tar格式
-a | --data-only:只备份数据,不包含表结构
-s | --schema-only:只备份表结构,不包含数据
-c | --clean:是否生成清理该数据库对象的语句,如drop table
-C | --create:是否包含create database语句
-n | --schema:只备份匹配的schema下的内容
-t | --table:只备份指定表
-T | --exclude-table=TABLE_NAME:指定不需要备份的表
--inserts:将备份数据转为insert格式,方便导入到其他数据库中。不使用该选项的话默认是使用copy的方式进行数据还原,速度会比insert快很多,所以如果是pgsql之间进行备份还原不建议使用该选项
--exclude-schema=SCHEMA_NAME:指定不需要备份的SCHEMA
--lock-wait-timeout=10s:备份时锁超时时间,避免备份期间有事务一直未执行完成导致备份卡住
2、pg_dump备份示例
#备份ywpie的数据为SQL格式然后进行还原,恢复数据前需要先创建好数据库 pg_dump -h 192.168.0.103 -U tanglu linuxe > linuxe.sql psql -h 192.168.0.103 -U tanglu -d linuxe -f linxue.sql #只备份表数据 pg_dump -h 127.0.0.1 -U postgres -p 5432 -W testdb -a > testdb.sql #只备份表结构 pg_dump -h 127.0.0.1 -U postgres -p 5432 -W testdb -s > testdb.sql
3、pg_dumpall备份示例
#备份所有数据库 pg_dumpall > sqlrestore/pg_all.sql #只备份角色 pg_dumpall -r > /data/backup/pg_roles.sql #只备份表空间 pg_dumpall -t > /data/backup/pg_tablespace.sql
4、pg_restore还原示例
-d:指定恢复备份文件到哪个schema中
pg_dump -h 192.168.0.103 -U tanglu -Fc ywpie > ywpie.dump #-F指定格式为dump专有格式 pg_restore -h 192.168.0.103 -U tanglu -d ywpie ywpie.dump #还原数据到linuxe库中
猜你喜欢
MySQL | Oracle Oracle教程(4)快照与AWR报告
一、Oracle 快照Oracle中的快照(Snapshot)是指数据库在某个时间点对性能相关的数据做的一次全量采集。包括:系统资源使用情况、Top SQL、IO 性能指标、SGA、PGA 使用情况。...
MySQL | Oracle Oracle教程(3)Schema、用户与表空间
在完成 Oracle安装后,登录数据库实例可以看到有很多的模式(Schema),这些模式都是为了支持数据库核心组件、特性扩展、管理任务或者示例而创建,对于这部分默认模式,通常不需要进行操作。在生产规范...
MySQL | Oracle Oracle教程(2)Oracle19C命令行静默安装教程
在部分生产环境下可能并不支持通过图形化方式来安装Oracle数据库(比如需要脚本一键安装的场景),所以还需要了解通过命令行静默安装的方式来完整数据库的安装,以下是详细步骤一、系统环境配置部分1、确定内...
MySQL | Oracle Oracle教程(1)Oracle19C图形化安装详细教程
一、Oracle数据库版本说明Oracle作为最出名的商业数据库,其特点是可用性强、扩展性强、安全性强、稳定性强。相比MySQL,更适合高并发的业务。从18c版本开始,Oracle采用年份来对版本进行...
PostgreSQL PostgreSQL教程(13)使用pgbench进行基准测试
pgbench是一款 PostgreSQL 官方自带的数据库性能基准测试工具,可以模拟多用户并发事务,用于评估数据库在不同并发度、数据量和硬件环境下的性能表现。一、pgbench常用选项 ...
文章评论