PostgreSQL备份与恢复示例
来源:互联网 发布:英雄连2英军单位数据 编辑:程序博客网 时间:2024/05/04 10:17
Postgresql的备份分为三种:
l SQL转储
l 文件系统级别备份(冷备份)
l 在线热备份(归档)
以下通过实例来讲解PostgreSQL
二、SQL转储
(一)pg_dump
这种备份方式产生一个文本文件,里面包含创建各种数据库对象的SQL语句和每个表中的数据。另外,表上创建的索引中的数据不会被导出,只会导出索引的定义 信息。在恢复数据库的时候,索引会被重建。可以使用数据库提供的工具pg_dumpall和pg_dump来进行备份。pg_dumpall会备份一个数据库集群中的所有信息和数据。pg_dump只备份数据库集群中的某个数据库的数据,它不会导出角色和表空间相关的信息,因为这些信息是整个数据库集群共 用的,不属于某个单独的数据库。pg_dump的基本用法如下:
备份
pg_dump [dbname] > [outfile]
例:pg_dump > /usr/local/pgsql/backup/pg.dmp
恢复
创建新数据库(恢复之前需创建数据库)createdb [dbname]
psql [dbname] < [outfile]
至此,数据已成功恢复!
注:pg_dump可以对针对单表或者多表进行备份
如:pg_dump databasename –t [tablename1] –t [tablename2] >filename
(二)pg_dumpall
pg_dump只能备份单个数据库,而且恢复的时候需要创建空数据库。pg_dumpall可以备份所有数据库,并且备份角色、表空间。
备份
pg_dumpall [dbname] > [outfile]
例:pg_dumpall > /usr/local/pgsql/backup/pg_all.dmp
恢复
psql -f [outfile] [username]
例:psql –f /usr/local/pgsql/backup/pg_all.dmp postgres
可以指定任何数据库名,如果恢复到一个空的集群中,通常使用postgres数据库
至此,数据已成功恢复!
(三)备份压缩与分割
压缩与分割的原理都是利用Linux的管线(PIPE)命令。
1)压缩
l 备份:
pg_dump dbname | gzip > filename.gz
l 恢复
gunzip -c filename.gz | psql dbname
2)分割
l 备份:
pg_dump dbname | split -b1m- filename
l 恢复
cat filename* | psql dbname
默认的情况下,pg_dump使用当前的操作系统用户作为连接数据库时使用的用户。可以使用选项-U或者设置环境变量PGUSER来指定连接数据库时使用的用户名。
例如:pg_dump -U liming -h db_server1 -p 5432 product > backup_file
该命令使用用户liming连接机器db_server1上在端口5432处监听的数据库,将数据库product的数据备份到文件backup_file中。
一般情况下,应该使用超级用户连接数据库进行备份操作,因为超级用户可以访问数据库中的任何信息。使用普通数据用户连接数据库,有些表可能无法访问。
运行pg_dump时,数据可以正常地执行其它操作。但ALTER TABLE这类修改数据库对象定义的操作会受到影响,可能会长时间处于等待状态而无法执行,所以在运行pg_dump命令时,不要在数据库中运行修改数据库对象定义的操作。
另外要注意的是,如果数据库中有些表使用OID来实现外键约束,应当在备份数据库时同时备份表的OID信息,使用pg_dump时加上选项–o即可达到这个目的。
(三)文件系统级别备份(冷备份)
文件系统级别的备份是冷备份,需要停止数据库。
1,停止数据库
pg_ctl –D /usr/local/pgsql/data stop
2,备份数据库
tar –jcv –f /usr/local/pgsql/backup/filesystem.tar.bz2 /usr/local/pgsql/data/
3,删除/usr/local/pgsql/data/目录
rm –r /usr/local/pgsql/data/
4,解压备份文件到原目录
tar –jxv –f /usr/local/pgsql/backup/filesystem.tar.bz2 –C /
5,启动数据库
pg_ctl –D /usr/local/pgsql/data start
6,查看数据库pg1是否恢复
psql pg1
pg=# select * from tb1;
a
---
1
(1 rows)
7,查看数据库pg2是否恢复
psql pg2
pg=# select * from tb2;
a
---
2
(1 rows)
至此,数据已成功恢复!
四、 在线热备份(归档)
(一)备份
1,配置归档模式
配置归档需要编辑postgresql.conf文件,默认为与/usr/local/pgsql/data/目录下
vim /usr/local/pgsql/data/postgesql.conf
archive_mode = on
archive_command = ‘cp %p /usr/local/pgsql/backup/archived_log/%f’
注:%p要被归档的日志文件的路径,%f是要被归档的日志文件的文件名
2,启动数据库
pg_ctl –D /usr/local/pgsql/data start
3,创建数据库arch
createdb arch
4,创建表并插入记录
psql arch
arch=# create table tb(a int);
arch=# insert into tb(a) values(1);
5,创建备份
arch=# select pg_start_backup(‘baseline’);
6,备份整个data目录
tar –jcv –f /usr/local/pgsql/backup/baseline.tar.bz2 /usr/local/pgsql/data/
7,停止备份
psql arch
arch=# select pg_stop_backup();
8,插入新记录,然后切换日志,重复3次
arch=# insert into tb(a) values(2);
arch=# select pg_switch_xlog();
arch=# insert into tb(a) values(3);
arch=# select pg_switch_xlog();
arch=# insert into tb(a) values(4);
arch=# select pg_switch_xlog();
9,把/data/pg_xlog/下的WAL日志文件复制到预设的归档目录下,保证产生的WAL日志都已归档。
(二)恢复
1,停止数据库
pg_ctl –D /usr/local/pgsql/data/ stop
2,删除/data/
rm –r /usr/local/pgsql/data/
3,恢复备份
tar –jxv –f /usr/local/pgsql/backup/baseline.tar.bz2 –C /
4,清空/data/pg_xlog/目录下所有文件
rm –r /usr/local/pgsql/data/pg_xlog/
5,创建/pg_xlog/及其下面的archive_status目录
mkdir /usr/local/pgsql/data/pg_xlog/
mkdir /usr/local/pgsql/data/pg_xlog/archive_status
6,在/data/目录下创建recovery.conf
vim /usr/local/pgsql/data/recovery.conf
restore_command = ‘cp /usr/local/pgsql/backup/archived_log/%f “%p”’
7,启动数据库
pg_ctl –D /usr/local/pgsql/data/ start
一切正常的话数据库就会自动应用WAL日志进行恢复
8,查看数据库arch是否恢复
psql arch
arch=# select * from tb;
a
---
1
2
3
4
(4 rows)
至此,数据已经成功恢复!的三种备份。
- PostgreSQL 备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL备份与恢复示例
- PostgreSQL 备份与恢复
- PostgreSQL 备份与恢复
- PostgreSQL 备份与恢复
- postgresql如何备份与恢复
- Postgresql 备份与恢复研究
- Postgresql 数据库备份与恢复
- PostgreSQL数据库备份与恢复
- PostgreSQL物理备份与恢复
- PostgreSQL数据库备份与恢复
- postgresql热备份与恢复
- mini2440 rtc支持
- 足球与oracle系列(4):从巴西惨败于德国,想到,差异的RAC拓扑对比!
- NPAPI插件开发学习:NPAPI的介绍
- The Kernel Newbie Corner: Kernel Symbols: What's Available to Your Module, What Isn't
- 谁有Chart FX for .NET 6.2 For VS2003的破解,给我一份.【紧急】
- PostgreSQL备份与恢复示例
- POJ 1222 EXTENDED LIGHTS OUT
- OpenSessionInViewFilter 的配置及替代方案
- first day for new job
- NPAPI插件开发学习:Webkit的插件机制
- RabbitMQ (二)工作队列
- 如何:测试 UserControl 的运行时行为
- 自定义对象的归档 //类只有实现 NSCoding 协议才具备归档功能 归档最好定义成宏,笔误好发现.
- JAVA中的四种引用