`
J2EE小熊
  • 浏览: 108741 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

PostgreSQL备份与恢复示例

阅读更多

一、 简介
Postgresql的备份分为三种:
l SQL转储
l 文件系统级别备份(冷备份)
l 在线热备份(归档)
以下通过实例来讲解PostgreSQL的三种备份。
二、 SQL转储
(一)pg_dump
1,创建数据库
createdb pg
2,连入数据库pg
psql pg
3,创建测试表,插入数据
pg=# create table pg_test(a int);
pg=# insert into pg_test(a) values(1);
pg=# insert into pg_test(a) values(2);
4,查看数据
pg=# select * from tb;
a
---
1
2
(2 rows)
5,备份
pg_dump pg > /usr/local/pgsql/backup/pg.dmp
6,删除数据库pg
dropdb pg
7,创建新数据库(恢复之前需创建数据库)
createdb pg
8,恢复数据
psql pb < /usr/local/pgsql/backup/pg.dmp
9,查看数据是否回复
pg=# select * from tb;
a
---
1
2
(2 rows)
至此,数据已成功恢复!
注:pg_dump可以对针对单表或者多表进行备份
如:pg_dump databasename –t tablename1 –t tablename2 >filename
(二)pg_dumpall
pg_dump只能备份单个数据库,而且恢复的时候需要创建空数据库。pg_dumpall可以备份所有数据库,并且备份角色、表空间。
1,创建数据库
createdb pg1
createdb pg2
2pg1中创建表并插入数据
psql pg1
pg=# create table tb1(a int)
pg=# insert into tb1(a) values(1);
3pg2中创建表并插入数据
psql pg2
pg=# create table tb2(a int)
pg=# insert into tb2(a) values(2);
4,备份数据库
pg_dumpall > /usr/local/pgsql/backup/pg_all.dmp
5,删除数据库
dropdb pg1
dropdb pg2
6,恢复数据库
psql –f /usr/local/pgsql/backup/pg_all.dmp postgres
可以指定任何数据库名,如果恢复到一个空的集群中,通常使用postgres数据库
7,查看数据库pg1是否恢复
psql pg1
pg=# select * from tb1;
a
---
1
(1 rows)
8,查看数据库pg2是否恢复
psql pg2
pg=# select * from tb2;
a
---
2
(1 rows)
至此,数据已成功恢复!
备份压缩与分割
压缩与分割的原理都是利用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
(三)文件系统级别备份(冷备份)
文件系统级别的备份是冷备份,需要停止数据库。
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 备份与恢复研究.txt

    ### PostgreSQL备份与恢复详解 #### 一、引言 在数据库管理中,数据备份与恢复是确保业务连续性和数据安全的重要环节。对于PostgreSQL这样的强大关系型数据库管理系统而言,掌握其备份与恢复策略尤为重要。本文将...

    postgresql数据库备份和恢复

    文档中的操作示例同时提供了Windows和Linux系统下的备份和恢复命令。在Linux环境下,可能需要使用不同的路径来指定 `pg_dump` 和 `psql`。具体路径依系统而定,通常安装路径可能类似于 `/opt/PostgreSQL/9.5/bin/`。...

    PostgreSQL 备份恢复技术手册 DBA必备

    五、pg_dump 备份恢复示例 1. 创建数据库:createdb testdb 2. 连入数据库:psql testdb 3. 创建测试表,插入数据:create table tt(a); insert into tt(a) values(1); insert into tt(a) values(2); 通过学习 ...

    postgresql数据库定时备份脚本(linux)

    一、PostgreSQL备份类型 1. **完整备份**:包含所有数据库对象,如表、索引、视图等。 2. **增量备份**:基于上一次完整备份,仅备份自上次备份以来更改的数据。 3. **差异备份**:与增量备份类似,但基于上一次完整...

    Python数据库备份与恢复:技术详解与代码实现

    本文详细介绍了如何使用Python进行数据库的备份与恢复,包括技术原理、代码示例和最佳实践。通过掌握这些技巧,你可以更好地保障数据的安全性和完整性。希望这篇文章能够成为你学习和应用Python数据库备份与恢复技术...

    PostgreSQL 9从零开始学 随书光盘资源1-5章

    分别介绍了PostgreSQL9的安装与配置、数据库的基本操作、数据表的基本操作、SQL语言基础、轻松掌握SQL语句、认识函数、PostgeSQL数据查询、数据的更新、创建和使用索引、事务和锁、视图操作、触发器、PostgreSQL的...

    PostgreSQL 9从零开始学 随书光盘资源10-18章

    分别介绍了PostgreSQL9的安装与配置、数据库的基本操作、数据表的基本操作、SQL语言基础、轻松掌握SQL语句、认识函数、PostgeSQL数据查询、数据的更新、创建和使用索引、事务和锁、视图操作、触发器、PostgreSQL的...

    postgresql实例参考(中文高清PDF)

    6. 复制与备份:主从复制,逻辑复制,备份与恢复策略。 7. 性能调优:查询优化,统计信息,索引选择,资源调度。 8. 扩展与插件:利用PL/pgSQL编写存储过程,安装第三方扩展。 四、学习路径 对于初学者,可以从基础...

    PostgreSQL 9从零开始学 随书光盘资源6-8章

    分别介绍了PostgreSQL9的安装与配置、数据库的基本操作、数据表的基本操作、SQL语言基础、轻松掌握SQL语句、认识函数、PostgeSQL数据查询、数据的更新、创建和使用索引、事务和锁、视图操作、触发器、PostgreSQL的...

    postgresql示例代码

    - **复制与备份**:PostgreSQL支持多种复制和备份策略,这可能在`Ch08`的某个部分有介绍,这对于高可用性和灾难恢复至关重要。 通过学习这些示例代码,你可以逐步掌握PostgreSQL的基础知识,并了解如何在实际项目...

    PostgreSQL中的备份表(不是数据库)

    1. **PostgreSQL备份概述**: - PostgreSQL是开源的对象关系型数据库系统,支持多种操作系统,包括Windows。 - 数据库备份是防止数据丢失的重要步骤,它可以通过复制数据库或其部分(如表)到安全存储来实现。 2....

    PostgreSQL实战

    同时,也会讨论备份与恢复策略,以应对可能的数据丢失风险。 最后,本书还会涉及监控和性能调优。通过监控工具和性能指标,可以诊断和解决性能问题。学习如何调整参数设置,优化查询执行计划,以达到最佳的运行状态...

    PostgreSQL 10 Administration Cookbook源码

    6. **备份与恢复**:PostgreSQL 10提供了多种备份策略,如物理备份、逻辑备份和基于时间点的恢复(Point-in-Time Recovery, PITR)。熟悉这些方法及其应用场景,能确保在系统故障时迅速恢复服务。 7. **并发控制**...

    PostgreSQL 10 DBA菜谱源码

    5. **备份与恢复**:PostgreSQL提供了pg_dump和pg_restore工具进行数据库备份和恢复,源码可能展示如何使用它们进行全量备份、增量备份和时间点恢复。 6. **安全性与权限管理**:学习如何设置用户、角色,分配权限...

    postgresql 9 administrator cookbook 第二版源码

    4. **备份与恢复**: - PostgreSQL提供了多种备份策略,如物理备份、逻辑备份和归档日志。源码中可能会有相关的脚本和方法,演示如何安全地备份和恢复数据库。 5. **复制与高可用性**: - PostgreSQL 9支持流复制...

    postgreSQL双机热备

    ### PostgreSQL 双机热备及自动化备份管理 #### 一、自动备份数据库 在 PostgreSQL 数据库管理系统中,实现数据的自动备份是一项非常重要的任务。它不仅能够帮助我们防止数据丢失,还能确保数据的一致性和完整性。...

    PostgreSQL 9从零开始学 随书光盘资源第9章

    分别介绍了PostgreSQL9的安装与配置、数据库的基本操作、数据表的基本操作、SQL语言基础、轻松掌握SQL语句、认识函数、PostgeSQL数据查询、数据的更新、创建和使用索引、事务和锁、视图操作、触发器、PostgreSQL的...

    Mac系统重置PostgreSQL密码的方法示例代码

    6. 恢复pg_hba.conf设置为md5并重启服务: 为了确保系统的安全性,需要将pg_hba.conf文件中的local行认证方法重新设置为md5,并且重启PostgreSQL服务,使其更改生效。 以上步骤是Mac系统下重置PostgreSQL密码的一...

Global site tag (gtag.js) - Google Analytics