欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PostgreSQL數(shù)據(jù)庫備份還原全攻略

 更新時間:2024年04月02日 11:37:32   作者:小馬穿云  
本文主要介紹邏輯備份和連續(xù)歸檔方式的備份及還原,文件系統(tǒng)級備份由于比較簡單,這里不在贅述,以下操作使用的數(shù)據(jù)庫版本為PostgreSQL 12.5,不同的數(shù)據(jù)庫版本在進(jìn)行連續(xù)歸檔操作時會有細(xì)微差異,需要的朋友可以參考下

前言

  • 邏輯備份
    即SQL轉(zhuǎn)儲方式,使用pg_dump和pg_dumpall進(jìn)行備份。邏輯備份在恢復(fù)時,介于邏輯備份與故障時間點之間的數(shù)據(jù)難以恢復(fù),所以邏輯備份適用于留存某個時間點的備份或進(jìn)行跨平臺跨版本的數(shù)據(jù)遷移。
  • 文件系統(tǒng)級備份
    即拷貝數(shù)據(jù)文件的完整目錄,備份時需要關(guān)閉數(shù)據(jù)庫?;謴?fù)數(shù)據(jù)庫時,只需將數(shù)據(jù)目錄復(fù)制到原來的位置。該方式實際工作中很少使用。
  • 連續(xù)歸檔
    該方式是把一個文件系統(tǒng)級別的全量備份和WAL(預(yù)寫式日志)級別的增量備份結(jié)合起來。當(dāng)需要恢復(fù)時,我們先恢復(fù)文件系統(tǒng)級別的備份,然后重放備份的WAL文件,把系統(tǒng)恢復(fù)到之前的某個狀態(tài)。

本文主要介紹邏輯備份和連續(xù)歸檔方式的備份及還原,文件系統(tǒng)級備份由于比較簡單,這里不在贅述。

以下操作使用的數(shù)據(jù)庫版本為PostgreSQL 12.5,不同的數(shù)據(jù)庫版本在進(jìn)行連續(xù)歸檔操作時會有細(xì)微差異。

一、邏輯備份

1.pg_dump工具

以下為pg_dump工具的常用參數(shù)選項(更多參數(shù)可使用pg_dump --help查看)

聯(lián)接選項:
-h, --host=主機名  數(shù)據(jù)庫服務(wù)器的主機名或套接字目錄
-U, --username=名字  以指定的數(shù)據(jù)庫用戶聯(lián)接
-d, --dbname=DBNAME  對數(shù)據(jù)庫 DBNAME備份
-p, --port=端口號  數(shù)據(jù)庫服務(wù)器的端口號
-w, --no-password  永遠(yuǎn)不提示輸入口令
-W, --password   強制口令提示 (自動)
--role=ROLENAME   在轉(zhuǎn)儲前運行SET ROLE

一般選項:
-f, --file=FILENAME   輸出文件或目錄名,導(dǎo)出到指定文件
-F, --format= p|c|d|t 導(dǎo)出文件格式(p|c|d|t)
		p:plain-輸出普通文字SQL腳本(默認(rèn));
		c:custom-輸出自定義歸檔格式,適用于pg_restore導(dǎo)入,該格式是最靈活導(dǎo)出方式,允許在導(dǎo)入時自定義選擇和重			排序歸檔條目。該格式默認(rèn)啟用壓縮;
		d:directory-輸出文件夾歸檔格式,適用于pg_restore導(dǎo)入。該格式會創(chuàng)建一個文件夾,一個表對應(yīng)一個文件。該格式默認(rèn)啟用壓縮,并且支持并行導(dǎo)出;
		t:tar-輸出tar壓縮歸檔格式,適用于pg_restore導(dǎo)入。該格式將文件夾歸檔格式產(chǎn)生的文件夾壓縮成tar壓縮包。但該格式不支持壓縮(文件夾歸檔已經(jīng)壓縮了),并且在導(dǎo)入時也不能更改相關(guān)的表順序。
控制輸出內(nèi)容選項:
-s, --schema-only   只轉(zhuǎn)儲模式, 不包括數(shù)據(jù) 
-a, --data-only    只轉(zhuǎn)儲數(shù)據(jù),不包括模式
-t, --table=TABLE   只轉(zhuǎn)儲指定名稱的表
-T, --exclude-table=TABLE 不轉(zhuǎn)儲指定名稱的表
-C, --create     在轉(zhuǎn)儲中包括創(chuàng)建數(shù)據(jù)庫語句
-c, --clean:包含drop刪除語句,建議與--if-exists同時使用;
--if-exists,drop刪除語句時帶上IF EXISTS指令
-n, --schema=SCHEMA   只轉(zhuǎn)儲指定名稱的模式
-N, --exclude-schema=SCHEMA 不轉(zhuǎn)儲已命名的模式
-O, --no-owner    在明文格式中, 忽略恢復(fù)對象所屬者
-S, --superuser=NAME   在明文格式中使用指定的超級用戶名
--column-inserts    以帶有列名的INSERT命令形式轉(zhuǎn)儲數(shù)據(jù)
--inserts     以INSERT命令,而不是COPY命令的形式轉(zhuǎn)儲數(shù)據(jù)
--disable-triggers   在只恢復(fù)數(shù)據(jù)的過程中禁用觸發(fā)器
--exclude-table-data=TABLE 不轉(zhuǎn)儲指定名稱的表中的數(shù)據(jù)
--no-synchronized-snapshots 在并行工作集中不使用同步快照
--no-tablespaces    不轉(zhuǎn)儲表空間分配信息
--no-unlogged-table-data  不轉(zhuǎn)儲沒有日志的表數(shù)據(jù)
--quote-all-identifiers  所有標(biāo)識符加引號,即使不是關(guān)鍵字
--section=SECTION   備份命名的節(jié) (數(shù)據(jù)前, 數(shù)據(jù), 及 數(shù)據(jù)后)
--serializable-deferrable 等到備份可以無異常運行
--snapshot=SNAPSHOT   為轉(zhuǎn)儲使用給定的快照
--strict-names    要求每個表和/或schema包括模式以匹配至少一個實體

常用示例:

#備份schema及數(shù)據(jù),指定數(shù)據(jù)庫pg_hive,指定文件為pg_hive20210108.sql
pg_dump -h 127.0.0.1 -U postgres -d pg_hive -f /opt/pg_hive20210108.sql

#只備份schema
pg_dump -h 127.0.0.1 -U postgres -d pg_hive -s -f /opt/pg_hive20210108.sql

#只備份數(shù)據(jù)
pg_dump -h 127.0.0.1 -U postgres -d pg_hive -a -f /opt/pg_hive20210108.sql

#備份單個表
pg_dump -h 127.0.0.1 -U postgres -d pg_hive –t table1 -f /opt/pg_hive20210108.sql

#備份多個表
pg_dump -h 127.0.0.1 -U postgres -d pg_hive –t table1 –t table2 -f /opt/pg_hive20210108.sql

#以帶有列名的INSERT命令形式轉(zhuǎn)儲數(shù)據(jù)
pg_dump -h 127.0.0.1 -U postgres -d pg_hive --column-inserts -f /opt/pg_hive20210108.sql

#指定導(dǎo)出格式為自定義格式(二進(jìn)制形式)
pg_dump -h 127.0.0.1 -U postgres -d pg_hive -Fc -f /opt/pg_hive20210108.dump

#使用gzip壓縮轉(zhuǎn)儲(針對大型數(shù)據(jù)庫)
pg_dump -h 127.0.0.1 -U postgres -d pg_hive | gzip > /opt/pg_hive20210108_gz.sql.gz

#使用split切片文件(針對大型數(shù)據(jù)庫)
/pg_dump -h 127.0.0.1 -U postgres -d pg_hive | split -b 100m - /opt/pg_hive20210108_sp.sql

2.pg_dumpall工具

相對于pg_dump只能備份單個庫,pg_dumpall可以備份整個PostgreSql實例中所有的數(shù)據(jù),包括角色和表空間定義。

使用示例:

#備份整個postgresql實例中所有的數(shù)
pg_dumpall -h 127.0.0.1 -U postgres  -f /opt/pg_hive20210108_all.sql

二、邏輯備份還原

邏輯備份的還原命令為psql和pg_restore:

如果使用pg_dump未指定format(即未使用-F參數(shù)),則導(dǎo)出的是SQL腳本,導(dǎo)入時需用psql命令,否則用pg_restore還原。因這2個還原工具大部分參數(shù)與pg_dump含義相近,可使用命令后加–help查看詳細(xì)參數(shù)。

常用示例:

#pg_dump備份時未指定format,還原時用psql
psql -h 127.0.0.1 -U postgres -d pg_hive -f /opt/pg_hive20210108.sql

#pg_dump備份時候使用-F參數(shù)指定format,還原時用pg_restore 
pg_restore -h 127.0.0.1 -U postgres -d pg_hive /opt/pg_hive20210108.dump

#還原gzip壓縮數(shù)據(jù)庫備份
gunzip -c /opt/pg_hive20210108_gz.sql.gz | psql -h 127.0.0.1 -U postgres -d pg_hive

#還原切片數(shù)據(jù)庫備份
cat /opt/pg_hive20210108_sp.sql* | psql -h 127.0.0.1 -U postgres -d pg_hive

三、連續(xù)歸檔備份

連續(xù)歸檔是通過基礎(chǔ)備份和wal日志相結(jié)合的方式進(jìn)行備份,恢復(fù)的時候可以選擇恢復(fù)到指定的時間點、指定事務(wù)點、或者完全恢復(fù)到wal日志的最新位置。

操作步驟如下:

1、創(chuàng)建備份目錄

#創(chuàng)建基礎(chǔ)備份目錄
mkdir -p /data/pg_base
#創(chuàng)建wal日志備份目錄
mkdir -p /data/pg_archive

注意新建備份文件夾的權(quán)限及所有者,否則會備份失敗

#更新備份文件夾的所有者
chown postgres:postgres /data/pg_base
chown postgres:postgres /data/pg_archive

2、修改配置文件

打開postgresql.conf配置文件,修改以下3個參數(shù):

vi postgresql.conf

#wal_level中有三個主要的參數(shù):minimal、archive和hot_standby。1.minimal是默認(rèn)的值,它僅寫入崩潰或者突發(fā)關(guān)機時所需要的信息(不建議使用)。2.archive是增加wal歸檔所需的日志(最常用)。3.hot_standby是在備用服務(wù)器上增加了運行只讀查詢所需的信息,一般實在流復(fù)制的時候使用到
wal_level = archive
#開啟歸檔模式
archive_mode = on
#備份wal日志,每天生成一個日期命名的文件夾
archive_command = 'DIR=/data/pg_archive/`date +%F`; test ! -d $DIR && mkdir -p $DIR; test ! -f $DIR/%f && cp %p $DIR/%f'

3、重啟pg數(shù)據(jù)庫

命令為:pg_ctl restart

在這里插入圖片描述

4、創(chuàng)建表

該步驟為測試備份及恢復(fù)效果使用

--創(chuàng)建表,插入10條測試數(shù)據(jù):
create table test (id integer);
insert into test values(generate_series(1,10));

5、做基礎(chǔ)備份

pg_basebackup -Ft -Pv -Xf -z -Z5 -D /data/pg_base/`date +%F`

為了測試備份和恢復(fù)效果,再插入10條數(shù)據(jù),并進(jìn)行手動切換wal日志,執(zhí)行如下sql:

#插入數(shù)據(jù)
insert into test values(generate_series(1,10));
#切換wal日志
select pg_switch_wal();

四、連續(xù)歸檔恢復(fù)

1、創(chuàng)建data文件夾

#重命名原來的data文件夾
mv /pgsql/postgresql/data   /pgsql/postgresql/data.bak
#創(chuàng)建新的data文件夾
mkdir data 

2、解壓基礎(chǔ)備份至新建的data文件夾

#拷貝基礎(chǔ)備份到新建data文件夾
cp /data/pg_base/2021-01-15/base.tar.gz /pgsql/postgresql/data
#解壓文件
tar -zxvf base.tar.gz
#刪除基礎(chǔ)備份中的wal日志和postmaster.pid文件
Cd /pgsql/postgresql/data
rm -rf pg_wal
rm -rf postmaster.pid
#創(chuàng)建archive_status文件夾
mkdir -p pg_wal/archive_status

3、修改配置文件

vi postgresql.conf

#修改restore_command為要恢復(fù)的wal日志目錄
restore_command = 'cp /data/pg_archive/2021-01-15/%f %p'

4、新建recovery.signal文件

#恢復(fù)時依賴該文件,恢復(fù)至最新wal位置,文件無需添加內(nèi)容
touch recovery.signal

5、賦權(quán)并啟動數(shù)據(jù)庫

#新建的data文件夾更改所有者
chown -R  postgres:postgres /pgsql/postgresql/data
#修改data目錄權(quán)限,否則會因為目錄權(quán)限過大無法啟動數(shù)據(jù)庫
chmod 0700 data -R
#啟動數(shù)據(jù)庫
pg_ctl start

6、驗證恢復(fù)效果

如下圖,已通過基礎(chǔ)備份和wal日志恢復(fù)全部數(shù)據(jù)。

在這里插入圖片描述

總結(jié)

新創(chuàng)建文件夾時注意文件夾的歸屬及權(quán)限,否則會導(dǎo)致備份或恢復(fù)失敗。

以上就是PostgreSQL數(shù)據(jù)庫備份還原全攻略的詳細(xì)內(nèi)容,更多關(guān)于PostgreSQL備份還原的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • PostgreSQL教程(一):數(shù)據(jù)表詳解

    PostgreSQL教程(一):數(shù)據(jù)表詳解

    這篇文章主要介紹了PostgreSQL教程(一):數(shù)據(jù)表詳解表的定義、系統(tǒng)字段、表的修改、表的權(quán)限等4大部份內(nèi)容,內(nèi)容種包括表的創(chuàng)建、刪除、修改、字段的修改、刪除、主鍵和外鍵、約束添加修改刪除等,本文講解了,需要的朋友可以參考下
    2015-05-05
  • PostgreSQL 復(fù)制表的 5 種方式詳解

    PostgreSQL 復(fù)制表的 5 種方式詳解

    PostgreSQL 提供了多種不同的復(fù)制表的方法,它們的差異在于是否需要復(fù)制表結(jié)構(gòu)或者數(shù)據(jù),這篇文章主要介紹了PostgreSQL 復(fù)制表的 5 種方式,需要的朋友可以參考下
    2023-01-01
  • PostgreSQL之連接失敗的問題及解決

    PostgreSQL之連接失敗的問題及解決

    這篇文章主要介紹了PostgreSQL之連接失敗的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • PostgreSQL教程(四):數(shù)據(jù)類型詳解

    PostgreSQL教程(四):數(shù)據(jù)類型詳解

    這篇文章主要介紹了PostgreSQL教程(四):數(shù)據(jù)類型詳解,本文講解了數(shù)值類型、字符類型、布爾類型、位串類型、數(shù)組、復(fù)合類型等數(shù)據(jù)類型,需要的朋友可以參考下
    2015-05-05
  • pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序)

    pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序)

    這篇文章主要介紹了pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • SpringBoot連接使用PostgreSql數(shù)據(jù)庫的方法

    SpringBoot連接使用PostgreSql數(shù)據(jù)庫的方法

    這篇文章主要介紹了SpringBoot連接使用PostgreSql數(shù)據(jù)庫的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • postgresql 實現(xiàn)查詢某時間區(qū)間的所有日期案例

    postgresql 實現(xiàn)查詢某時間區(qū)間的所有日期案例

    這篇文章主要介紹了postgresql 實現(xiàn)查詢某時間區(qū)間的所有日期案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL 序列(Sequence) 與 Oracle 序列對比差異分析

    PostgreSQL 序列(Sequence) 與 Oracle 序列對比差異分

    PostgreSQL 和 Oracle 都提供了序列(Sequence)功能,但在實現(xiàn)細(xì)節(jié)和使用方式上存在一些重要差異,下面給大家介紹PostgreSQL 序列(Sequence) 與 Oracle 序列對比差異分析,感興趣的朋友一起看看吧
    2025-05-05
  • PostgreSQL自動更新時間戳實例代碼

    PostgreSQL自動更新時間戳實例代碼

    最近有這么一個工程,需要使用postgresql數(shù)據(jù)庫,在數(shù)據(jù)庫中的好幾個表中都需要時間戳這個字段,這篇文章主要給大家介紹了關(guān)于PostgreSQL自動更新時間戳的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • postgresql的jsonb數(shù)據(jù)查詢和修改的方法

    postgresql的jsonb數(shù)據(jù)查詢和修改的方法

    這篇文章主要介紹了postgresql的jsonb數(shù)據(jù)查詢和修改的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03

最新評論