• 技术文章 >数据库 >PostgreSQL

    postgresql数据库怎么恢复

    silencementsilencement2020-02-13 10:41:08原创1573

    Postgresql的备份分为三种:

    SQL转储

    文件系统级别备份(冷备份)

    在线热备份(归档)

    以下通过实例来讲解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

    (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;

    (2 rows)

    至此,数据已成功恢复!

    注:pg_dump可以对针对单表或者多表进行备份

    如:pg_dump databasename –t tablename1 –t tablename2 >filename

    (二)pg_dumpall

    pg_dump只能备份单个数据库,而且恢复的时候需要创建空数据库。pg_dumpall可以备份所有数据库,并且备份角色、表空间。

    1,创建数据库

    createdb pg1

    createdb pg2

    2, pg1中创建表并插入数据

    psql pg1

    pg=# create table tb1(a int)

    pg=# insert into tb1(a) values(1);

    3, pg2中创建表并插入数据

    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;

    (1 rows)

    8,查看数据库pg2是否恢复

    psql pg2

    pg=# select * from tb2;

    (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;

    (1 rows)

    7,查看数据库pg2是否恢复

    psql pg2

    pg=# select * from tb2;

    (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;

    (4 rows)

    至此,数据已经成功恢复!

    推荐学习《Python教程》。

    专题推荐:数据库
    上一篇:postgresql系统表怎么看 下一篇:postgresql怎么重启

    相关文章推荐

    • 如何进入postgresql

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网