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

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

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

前言

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

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

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

一、邏輯備份

1.pg_dump工具

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

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

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

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

#使用gzip壓縮轉儲(針對大型數(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ù)),則導出的是SQL腳本,導入時需用psql命令,否則用pg_restore還原。因這2個還原工具大部分參數(shù)與pg_dump含義相近,可使用命令后加–help查看詳細參數(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ù)歸檔是通過基礎備份和wal日志相結合的方式進行備份,恢復的時候可以選擇恢復到指定的時間點、指定事務點、或者完全恢復到wal日志的最新位置。

操作步驟如下:

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

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

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

#更新備份文件夾的所有者
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是默認的值,它僅寫入崩潰或者突發(fā)關機時所需要的信息(不建議使用)。2.archive是增加wal歸檔所需的日志(最常用)。3.hot_standby是在備用服務器上增加了運行只讀查詢所需的信息,一般實在流復制的時候使用到
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)建表

該步驟為測試備份及恢復效果使用

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

5、做基礎備份

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

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

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

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

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

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

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

#拷貝基礎備份到新建data文件夾
cp /data/pg_base/2021-01-15/base.tar.gz /pgsql/postgresql/data
#解壓文件
tar -zxvf base.tar.gz
#刪除基礎備份中的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為要恢復的wal日志目錄
restore_command = 'cp /data/pg_archive/2021-01-15/%f %p'

4、新建recovery.signal文件

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

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

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

6、驗證恢復效果

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

在這里插入圖片描述

總結

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

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

相關文章

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

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

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

    PostgreSQL 復制表的 5 種方式詳解

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

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

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

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

    這篇文章主要介紹了PostgreSQL教程(四):數(shù)據(jù)類型詳解,本文講解了數(shù)值類型、字符類型、布爾類型、位串類型、數(shù)組、復合類型等數(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ù)庫的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    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)細節(jié)和使用方式上存在一些重要差異,下面給大家介紹PostgreSQL 序列(Sequence) 與 Oracle 序列對比差異分析,感興趣的朋友一起看看吧
    2025-05-05
  • PostgreSQL自動更新時間戳實例代碼

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

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

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

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

最新評論