postgresql 备份

PostgreSQL备份与恢复示例

文档控制

l       文档变更记录


日期


版本号


作者


备注


2009-8-13


v1.0


陈浩


创建

TOC \o "1-3" \h \z \u

PostgreSQL备份与恢复

文档控制

一、       简介

二、       SQL转储

(一)pg_dump

(二)pg_dumpall;

(三)备份压缩与分割

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

四、       在线热备份(归档)

(一)备份

(二)恢复

一、      简介

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

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;

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 -b 1m - 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)

至此,数据已成功恢复!

时间: 2024-10-20 21:24:05

postgresql 备份的相关文章

postgresql备份恢复数据库和批量导入导出数据到文件方法

备份数据库:pg_dump -h localhost -U root demo02 > /home/arno/dumps/demo02.bak 恢复数据库:psql -h localhost -U root -d demo <  demo.bak 备份表:pg_dump -h localhost -U root demo02 -t books > /home/arno/dumps/books.bak 恢复表:psql -h localhost -U root -d demo -t boo

PostgreSQL备份之pg_rman

一. 安装 PostgreSQL版本是9.4.4 # git clone -b REL9_4_STABLE https://github.com/ossc-db/pg_rman.git Initialized empty Git repository in /opt/pg_rman/.git/ remote: Counting objects: 1939, done. remote: Total 1939 (delta 0), reused 0 (delta 0), pack-reused 19

PostgreSQL备份之手工备份(Low Level API)

一.备份 1. 需要保证archive_mode = on 和 archive_command是有效的 2. 在master节点上连接上数据库并执行 SELECT pg_start_backup('label', true); pg_start_backup第二个参数设置为true的好处是备份开始会执行一个检查点,设置为true能尽快的完成检查点,并且能减少备份期间产生的wal文件,但是会对查询有影响,默认设置的checkpoint_completion_target的一半的时间,半夜的备份建议

PostgreSQL备份之pg_basebackup

一.准备 连接上master节点创建replication用户 # CREATE ROLE replicator with login replication password 123456: 修改白名单pg_hba.conf # host    replication    all        xxxxx/32    md5 二.制作基础备份 # pg_basebackup --format=tar \ #使用打包方式备份 --xlog-method=fetch \    #获取wal文件方

postgresql 备份 还原

windows  linux 通用 第一步:通过 cmd 进入到postgresql 安装目录的 bin 下: cd C:\PostgreSQL\pg95\bin 第二步:备份数据库 pg_dump -h localhost -U TPlusPosAdmin -d tegen -f "C:\testdatabase.bak" -h:数据库服务器地址: -p:数据库端口号: -U:U 大写,表示用户名: -d:数据库名称:-f:把备份文件放在哪里: 第三步:还原数据库(你要还原的数据库软

postgreSQL备份数据

1.pg_dump 备份单一数据库 pg_dump仅导出数据库结构:pg_dump -U TestRole1 -s -f TestDb1.sql TestDb1 备份某个database,备份结果以自定义压缩格式输出:pg_dump -h localhost -p 5432 -U someuser -F c -b -v -f mydb.backup mydb 备份某个database,备份结果以SQL文本方式输出,输出结果中需包括CREATE DATABASE语句:pg_dump -h loca

postgreSQL 备份多张表

-U表示用户 -h表示主机 -p表示端口号 -t表示表名 -f表示备份后的sql文件的名字 -d表示要恢复数据库名 一.打开cmd 进入postgresql安装路径下的bin文件夹,以我的为例: cd D:\Program Files\PostgreSQL\bin 二.输入备份命令,多个表每个表前面都要加 -t: 输入口令,即你的数据库登录密码,完成备份. pg_dump -U postgres -h localhost -p 5432 -t fsrd_user -t fsrd_tenant -

PostgreSQL备份之omniPITR

一.准备 1. 安装 omnipitr是用perl写的,直接下载下来就可以用了 # git clone https://github.com/omniti-labs/omnipitr.git /opt/omnipitr/ Initialized empty Git repository in /opt/omnipitr/.git/ remote: Counting objects: 2627, done. remote: Total 2627 (delta 0), reused 0 (delta

postgreSQL备份脚本删除3天前备份同时压缩昨天备份

脚本功能: 系统环境:SUSE Linux Server 11.3 X64 1.删除3天前压缩文件(.bak.tar.gz) 2.备份数据库(未压缩文件.bak) 3.压缩昨天数据库备份文件(.bak.tar.gz),删除昨天数据库备份未压缩文件(.bak) #!/bin/bash export PATH=$PATH:/usr/local/pgsql/bin DATE=`date +%Y_%m_%d_%H` YESDAY=`date -d "yesterday" +%Y_%m_%d_%