
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 MySQL教程(11)物理备份工具Xtrabackup使用教程
一、Xtrabackup 介绍Xtrabackup是Percona出品的一款针对MySQL的物理备份工具。物理备份通常是指直接对数据文件、日志文件、配置文件等对象直接进行复制的一种备份方法。...

MySQL MySQL教程(10)逻辑备份工具mysqldump使用教程
一、MySQL逻辑备份介绍逻辑备份是指通过导出数据库中的逻辑信息(如表结构、视图、索引、存储过程、数据内容等)并保存为可读格式的过程。它将数据库数据以SQL语句或其他标准格式(如CSV、JSON)输出...

PostgreSQL PostgreSQL教程(12)基于流复制的主从集群
一、PostgreSQL 流复制概念在PostgreSQL中,通过流复制(Streaming Replication)实现主从架构,保证数据安全性的同时提高读写性能与容灾能力。流复制的实现方...

PostgreSQL PostgreSQL教程(11)第三方物理备份工具pg_rman使用教程
pg_rman是一款PostgreSQL第三方物理备份工具,支持对整个数据库集群、归档日志和服务器日志进行在线备份。由于pg_rman是基于本地数据拷贝的方式,而不是流式备份,所以要求 pg...

PostgreSQL PostgreSQL教程(10)物理备份工具pg_basebackup使用教程
一、PostgreSQL 物理备份介绍物理备份是通过复制整个数据目录来对数据库实现备份的一种高效手段,备份对象包括所有的数据文件、WAL 日志以及相关的配置文件。在 PostgreSQL 中核心物理备...
文章评论