postgresql同样支持在线备份,该备份方式与oracle中用户热备的方式相同,手动拷贝数据文库文件与归档日志。可以根据测试过程将备份直接写成script,通过定制,完成数据库的自动备份。
postgresql的恢复支持基于时间戳与事务ID,可以通过时间戳或事务ID的方式,完成数据库的不完全恢复或者因错误操作的故障恢复。
该测试目的:postgresql的在线备份;通过在线备份完成恢复。
1,开启归档
  [postgre@daduxiong ~]$ more /usr/local/pgsql/data/postgresql.conf |grep archive_  
archive_mode = on               # allows archiving to be done 
archive_command = ‘cp -i %p /archive/%f >/dev/null’
2,重新启动数据库
[root@daduxiong ~]# service postgresql stop  
Stopping PostgreSQL: server stopped 
ok 
[root@daduxiong ~]# service postgresql start 
Starting PostgreSQL: ok
3,启动备份
[postgre@daduxiong archive]$ psql postgres -c “select pg_start_backup(‘hot_backup’);”   
 pg_start_backup  
—————– 
 0/7000020 
(1 row)
4,使用tar命令备份数据库文件,不包含pg_xlog目录
| [postgre@daduxiong archive]$ tar –exclude $PGDATA/pg_xlog -cvjpf /archive/pgbackup.tar.bz2 $PGDATA | 
5,完成备份
| [postgre@daduxiong archive]$ psql postgres -c “select pg_stop_backup();” pg_stop_backup —————- 0/70133A0(1 row) | 
6,在postgres数据库中创建表并插入记录,作为恢复时的判断。
[postgre@daduxiong archive]$ psql postgres  
Welcome to psql 8.3.10, the PostgreSQL interactive terminal. 
Type:  copyright for distribution terms 
       h for help with SQL commands 
       ? for help with psql commands 
       g or terminate with semicolon to execute query 
       q to quit 
postgres=# create table abc(id integer); 
CREATE TABLE 
postgres=# insert into abc values(1); 
INSERT 0 1 
postgres=# q
7,此时假设数据库出现问题,停止数据库,拷贝日志
[root@daduxiong pgsql]# service postgresql stop  
Stopping PostgreSQL: server stopped 
ok 
[postgre@daduxiong archive]$ cp $PGDATA/pg_xlog/*00* /archive/
8,删除”发生错误”的data目录
| [root@daduxiong pgsql]# rm -rf data | 
9,解压之前的备份文件压缩包
[postgre@daduxiong pgsql]$ tar -xvf /archive/pgbackup.tar.bz2  
….省略 
/usr/local/pgsql/data/global/2843 
/usr/local/pgsql/data/postmaster.opts 
/usr/local/pgsql/data/pg_twophase/ 
/usr/local/pgsql/data/postmaster.pid 
/usr/local/pgsql/data/backup_label 
/usr/local/pgsql/data/PG_VERSION
10,恢复data目录,重新创建pg_xlog目录及其子目录archive_status
[root@daduxiong pgsql]# mv /archive/usr/local/pgsql/data /usr/local/pgsql  
[root@daduxiong data]# mkdir pg_xlog 
[root@daduxiong data]# chmod 0700 pg_xlog/ 
[root@daduxiong data]# chown postgre:postgre pg_xlog/ 
[root@daduxiong data]# cd pg_xlog/ 
[root@daduxiong pg_xlog]# mkdir archive_status 
[root@daduxiong pg_xlog]# chmod 0700 archive_status/ 
[root@daduxiong pg_xlog]# chown postgre:postgre archive_status/ 
[root@daduxiong pg_xlog]# mv /archive/*00* /usr/local/pgsql/data/pg_xlog 
[root@daduxiong pg_xlog]# cd .. 
[root@daduxiong data]# ls 
backup_label  pg_clog        pg_multixact  pg_twophase  postgresql.conf 
base          pg_hba.conf    pg_subtrans   PG_VERSION   postmaster.opts 
global        pg_ident.conf  pg_tblspc     pg_xlog      postmaster.pid
11,配置恢复配置文件
| [root@daduxiong data]# touch recovery.conf [root@daduxiong data]# echo “restore_command=’cp -i /archive/%f %p'” >>recovery.conf [root@daduxiong data]# chown postgre:postgre recovery.conf [root@daduxiong data]# chmod 0750 recovery.conf | 
12,启动数据库,观察数据库启动的日志
| [root@daduxiong data]# service postgresql start Starting PostgreSQL: ok —省略日志部分内容 LOG: selected new timeline ID: 3 LOG: restored log file “00000002.history” from archive LOG: archive recovery complete LOG: autovacuum launcher started LOG: database system is ready to accept connections | 
13,验证恢复结果。检查之前创建的表与记录。
| [postgre@daduxiong archive]$ psql postgres Welcome to psql 8.3.10, the PostgreSQL interactive terminal. Type: copyright for distribution terms h for help with SQL commands ? for help with psql commands g or terminate with semicolon to execute query q to quit postgres=# select * from abc; id —- 1 (1 row) postgres=# q [root@daduxiong data]# ls -l total 80 -rw——- 1 postgre postgre 147 Aug 31 10:26 backup_label.old drwx—— 6 postgre postgre 4096 Aug 27 11:33 base drwx—— 2 postgre postgre 4096 Aug 31 10:41 global drwx—— 2 postgre postgre 4096 Aug 10 11:06 pg_clog -rwx—— 1 postgre postgre 3429 Aug 10 11:10 pg_hba.conf -rwx—— 1 postgre postgre 1460 Aug 10 11:06 pg_ident.conf drwx—— 4 postgre postgre 4096 Aug 10 11:06 pg_multixact drwx—— 2 postgre postgre 4096 Aug 10 11:06 pg_subtrans drwx—— 2 postgre postgre 4096 Aug 10 11:06 pg_tblspc drwx—— 2 postgre postgre 4096 Aug 10 11:06 pg_twophase -rwx—— 1 postgre postgre 4 Aug 10 11:06 PG_VERSION drwx—— 3 postgre postgre 4096 Aug 31 10:35 pg_xlog -rwx—— 1 postgre postgre 16727 Aug 31 09:42 postgresql.conf -rwx—— 1 postgre postgre 59 Aug 31 10:35 postmaster.opts -rw——- 1 postgre postgre 47 Aug 31 10:35 postmaster.pid -rwxr-x— 1 postgre postgre 39 Aug 31 10:34 recovery.done | 
说明:
该测试中采用的是系统安装默认的数据,如果是生产库需要注意备份所有的表空间,不能仅仅备份软连接.
数据库完成备份后,recovery.conf文件变成recovery.done,backup_label文件变成了backup_lable.old.
oracle的备份通常采用RMAN工具备份,该工具功能强大,使用方便,得到大家的认可。
开源项目组也为postgresql开发了一款类似的工具pg-rman,其功能也很强大,使用方式和特点与ORACLE的RMAN非常类似。
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
 
                        TechTarget
官方微博
 
                        TechTarget中国
相关推荐
- 
            MongoDB收购Realm数据库以增强移动力量日前MongoDB公司宣布收购开源数据库供应商Realm公司,以帮助其在日益移动化计算领域提升竞争能力。 Re […] 
- 
            低成本和云选项推动开源RDBMS的部署随着企业产生越来越多的数据,数据专业人员面临困境:在此过程中数据库账单必须变得更多吗?对此,越来越多注重成本的 […] 
- 
            2017年1月数据库流行度排行榜 新年新气象新年新气象,数据库知识网站DB-engines最近更新了2017年1月份数据库流行度榜单。TechTarget数据库网站将与您分享1月份的榜单排名情况,让我们拭目以待。 
- 
            2016年12月数据库流行度排行榜 几家欢乐几家愁在过去的6个月中,数据库排行榜的前二十名总体上没有太大的变动,那么数据库知识网站DB-engines最近更新的2016年12月份数据库流行度排名情况是否一如既往的沉寂、低调呢? 
