热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

PostgreSQL备份与恢复方法

一、简介Postgresql的备份分为三种:lSQL转储l文件系统级别备份(冷备份)l在线热备份(归档)以下通过实例来讲解PostgreSQL的三种备份。二、SQL转储(一)pg_dump1,创建数据库createdbpg2,连入数据库pgpsqlpg3,创建测试表,插入数据

   一、 简介

    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

    9,查看数据是否回复

    pg=# select * from tb;

    a

    ---

    1

    2

    (2 rows)

    至此,数据已成功恢复!

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

    如:pg_dump databasename Ct tablename1 Ct 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 Cf /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 CD /usr/local/pgsql/data stop

    2,备份数据库

    tar Cjcv Cf /usr/local/pgsql/backup/filesystem.tar.bz2 /usr/local/pgsql/data/

    3,删除/usr/local/pgsql/data/目录

    rm Cr /usr/local/pgsql/data/

    4,解压备份文件到原目录

    tar Cjxv Cf /usr/local/pgsql/backup/filesystem.tar.bz2 CC /

    5,启动数据库

    pg_ctl CD /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 CD /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 Cjcv Cf /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 CD /usr/local/pgsql/data/ stop

    2,删除/data/

    rm Cr /usr/local/pgsql/data/

    3,恢复备份

    tar Cjxv Cf /usr/local/pgsql/backup/baseline.tar.bz2 CC /

    4,清空/data/pg_xlog/目录下所有文件

    rm Cr /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,启动数据库


推荐阅读
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
    本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
  • 2019年独角兽企业招聘Python工程师标准课程概览
    本文详细介绍了2019年独角兽企业在招聘Python工程师时的标准课程内容,包括Shell脚本中的逻辑判断、文件属性判断、if语句的特殊用法及case语句的应用。 ... [详细]
  • 解决Linux中wget无法解析主机的问题
    本文介绍了如何通过修改/etc/resolv.conf文件来解决Linux系统中wget命令无法解析主机名的问题,通过添加Google的公共DNS服务器地址作为解决方案。 ... [详细]
  • 本文详细介绍了如何利用Xshell配合Xftp实现文件传输,以及如何使用Pure-FTPd构建FTP服务,并探讨了VSFTP与MySQL结合存储虚拟用户的方法。 ... [详细]
  • JUnit下的测试和suite
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文详细介绍了在 Ubuntu 16.04 系统上安装和配置 PostgreSQL 数据库的方法,包括如何设置监听地址、启用密码加密、更改默认用户密码以及调整客户端访问控制。 ... [详细]
  • 本文详细介绍了如何在ARM架构的目标设备上部署SSH服务端,包括必要的软件包下载、交叉编译过程以及最终的服务配置与测试。适合嵌入式开发人员和系统集成工程师参考。 ... [详细]
  • flea,frame,db,使用,之 ... [详细]
  • 1、什么是过滤器管道使用竖线(|)将两个命令隔开,竖线左边命令的输出就会作为竖线右边命令的输入。连续使用竖线表示第一个命令的输出会作为第二个命令的输入,第二个命令的输出又会作为第三个命令的输入, ... [详细]
  • 如何处理PHP缺少扩展的问题
    本文将详细介绍如何解决PHP环境中缺少扩展的问题,包括检查当前环境、修改配置文件以及验证修改是否生效的具体步骤,帮助开发者更好地管理和使用PHP扩展。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中安装 Python 3.7 的步骤,包括编译工具的安装、Python 3.7 源码的下载与编译、软链接的创建以及常见错误的处理方法。 ... [详细]
  • 构建个人多节点Linux环境(CodeSheep)
    本文介绍如何通过虚拟机搭建一个多节点的Linux环境,这对于学习、实验和项目部署都具有重要意义。文章详细讲解了网络IP设置、节点间通信等关键步骤。 ... [详细]
  • Linux系统快捷键大全及使用技巧
    本文详细介绍了Linux系统中的各种快捷键,包括命令行和VIM编辑器中的常用快捷键,帮助用户提高操作效率。同时,文章还提供了关于字体配置、软件安装等方面的实用信息。 ... [详细]
  • Ubuntu 14.04 系统安装后网卡名称修改方法
    本文介绍了在安装 Ubuntu 14.04 Server 版本后,如何将默认的网卡名称从非 eth 格式修改为传统的 eth 格式,并提供了详细的步骤和示例。 ... [详细]
author-avatar
可爱嘟嘟豬5
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有