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

PostgreSQL數(shù)據(jù)庫備份與恢復(fù)的四種辦法

 更新時間:2025年01月11日 14:13:30   作者:xiongood  
在數(shù)據(jù)為王的時代,數(shù)據(jù)庫中存儲的信息堪稱企業(yè)的生命線,而PostgreSQL作為一款廣泛應(yīng)用的開源數(shù)據(jù)庫,學(xué)會如何妥善進(jìn)行備份與恢復(fù)操作,是每個開發(fā)者與運(yùn)維人員必備的技能,今天,咱們就深入探究一下PostgreSQL相關(guān)的備份恢復(fù)策略,并附上豐富的代碼示例

在數(shù)據(jù)為王的時代,數(shù)據(jù)庫中存儲的信息堪稱企業(yè)的生命線,而PostgreSQL作為一款廣泛應(yīng)用的開源數(shù)據(jù)庫,學(xué)會如何妥善進(jìn)行備份與恢復(fù)操作,是每個開發(fā)者與運(yùn)維人員必備的技能。今天,咱們就深入探究一下PostgreSQL相關(guān)的備份恢復(fù)策略,并附上豐富的代碼示例。

一、pg_dump:邏輯備份的利器

pg_dump是PostgreSQL自帶的用于生成數(shù)據(jù)庫邏輯備份的工具。它能把數(shù)據(jù)庫的結(jié)構(gòu)以及數(shù)據(jù),以SQL腳本的形式導(dǎo)出,方便在其他環(huán)境里重建。

  1. 備份單個數(shù)據(jù)庫 假設(shè)我們有個名為test_db的數(shù)據(jù)庫,要將它完整備份下來,操作如下:
pg_dump -U your_username -Fc test_db > test_db.dump

這里,-U指定用戶名,-Fc表示以自定義的壓縮二進(jìn)制格式導(dǎo)出,這種格式備份速度較快,而且生成的文件體積較小 。最后將備份內(nèi)容重定向到test_db.dump文件中。

  1. 備份指定表 要是只想備份數(shù)據(jù)庫里的部分表,例如test_db中的users表和orders表:
pg_dump -U your_username -t users -t orders -Fc test_db > partial_dump.dump

-t參數(shù)用來指定需要備份的表名,可以多次使用這個參數(shù)來添加多個目標(biāo)表。

二、pg_restore:邏輯備份的恢復(fù)操作

有了備份文件,借助pg_restore就能讓數(shù)據(jù)起死回生。

  1. 恢復(fù)完整數(shù)據(jù)庫 先創(chuàng)建一個空的目標(biāo)數(shù)據(jù)庫,假設(shè)叫new_test_db,然后執(zhí)行恢復(fù):
createdb -U your_username new_test_db
pg_restore -U your_username -d new_test_db test_db.dump

createdb用于創(chuàng)建新數(shù)據(jù)庫,-d參數(shù)在pg_restore里表示目標(biāo)數(shù)據(jù)庫,按照備份文件test_db.dump中的指令,把數(shù)據(jù)和結(jié)構(gòu)填充進(jìn)新的new_test_db數(shù)據(jù)庫。

  1. 恢復(fù)部分表 如果只想恢復(fù)之前備份里的部分表,例如只恢復(fù)users表:
pg_restore -U your_username -d new_test_db -t users test_db.dump

-t參數(shù)的含義和備份時一致,精準(zhǔn)定位到需要恢復(fù)的表。

三、pg_basebackup:物理備份的實(shí)現(xiàn)

物理備份會直接拷貝數(shù)據(jù)庫文件,相較于邏輯備份,速度更快,適合大型數(shù)據(jù)庫。

  1. 基礎(chǔ)物理備份 以超級用戶身份執(zhí)行以下命令:
pg_basebackup -D /path/to/backup -U your_superuser -P

-D指定備份文件存放的目錄,-U是超級用戶用戶名,-P 會顯示備份進(jìn)度,讓我們能實(shí)時知曉備份狀態(tài)。不過物理備份要注意,目標(biāo)目錄必須為空,而且在備份期間數(shù)據(jù)庫讀寫操作盡量減少,避免數(shù)據(jù)不一致。

  1. 增量物理備份 先完成一次基礎(chǔ)物理備份,后續(xù)增量備份基于這個基礎(chǔ)來做。我們要記錄下基礎(chǔ)備份的 WAL(Write-Ahead Logging,預(yù)寫式日志)文件位置。增量備份時:
pg_basebackup -D /path/to/incremental_backup -U your_superuser -P -X stream -C -R \
--checkpoint=fast --target-wal-segment-size=16MB \
--write-recovery-conf --recovery-target-time='2025-01-15 12:00:00'

-X stream開啟流模式來傳輸WAL日志,-C表示在備份結(jié)束后清理不再需要的WAL段,-R自動生成恢復(fù)配置文件,后面幾個參數(shù)用于精細(xì)調(diào)整備份的檢查點(diǎn)和目標(biāo)WAL段大小,--recovery-target-time則設(shè)定恢復(fù)到的時間點(diǎn)。

四、基于WAL日志的恢復(fù)

WAL日志是PostgreSQL物理恢復(fù)的關(guān)鍵,就算數(shù)據(jù)庫出現(xiàn)故障,只要WAL日志完整,就能恢復(fù)到故障前的狀態(tài)。

假設(shè)數(shù)據(jù)庫崩潰了,先把物理備份文件拷貝到合適位置,然后利用WAL日志恢復(fù):

cp -R /path/to/backup /var/lib/postgresql/data
# 找到相關(guān)WAL日志,假設(shè)存放在 /var/lib/postgresql/wal_logs
cp /var/lib/postgresql/wal_logs/*.log /var/lib/postgresql/data/pg_wal
# 啟動PostgreSQL服務(wù),它會自動根據(jù)WAL日志恢復(fù)數(shù)據(jù)
sudo systemctl start postgresql

五、總結(jié)

掌握這些備份與恢復(fù)手段,就像是給PostgreSQL數(shù)據(jù)庫穿上了堅(jiān)固的鎧甲,無論遭遇意外刪除、硬件故障還是其他數(shù)據(jù)危機(jī),都能沉著應(yīng)對,守護(hù)數(shù)據(jù)資產(chǎn)的安全與完整。

到此這篇關(guān)于PostgreSQL數(shù)據(jù)庫備份與恢復(fù)的四種辦法的文章就介紹到這了,更多相關(guān)PostgreSQL數(shù)據(jù)庫備份與恢復(fù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

  • postgresql連續(xù)歸檔及時間點(diǎn)恢復(fù)的操作

    postgresql連續(xù)歸檔及時間點(diǎn)恢復(fù)的操作

    這篇文章主要介紹了postgresql連續(xù)歸檔及時間點(diǎn)恢復(fù)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL LIKE 大小寫實(shí)例

    PostgreSQL LIKE 大小寫實(shí)例

    這篇文章主要介紹了PostgreSQL LIKE 大小寫實(shí)例,具有很好的參考價值,希望對大家有所幫助。 一起跟隨小編過來看看吧
    2021-01-01
  • 深入理解PostgreSQL的MVCC并發(fā)處理方式

    深入理解PostgreSQL的MVCC并發(fā)處理方式

    這篇文章主要介紹了深入理解PostgreSQL的MVCC并發(fā)處理方式,文中同時介紹了MVCC的缺點(diǎn),需要的朋友可以參考下
    2014-07-07
  • PostgreSQL數(shù)據(jù)DML誤操作恢復(fù)方法

    PostgreSQL數(shù)據(jù)DML誤操作恢復(fù)方法

    PostgreSQL是一種開源的對象關(guān)系型數(shù)據(jù)庫管理系統(tǒng),其DML(Data Manipulation Language)負(fù)責(zé)數(shù)據(jù)的操作和管理,那么如何DML誤操作了如何恢復(fù),所以本文介紹了PostgreSQL數(shù)據(jù)DML誤操作恢復(fù)方法,需要的朋友可以參考下
    2024-12-12
  • PostgreSQL 實(shí)現(xiàn)登錄及修改密碼操作

    PostgreSQL 實(shí)現(xiàn)登錄及修改密碼操作

    這篇文章主要介紹了PostgreSQL 實(shí)現(xiàn)登錄及修改密碼操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 關(guān)于PostgreSQL JSONB的匹配和交集問題

    關(guān)于PostgreSQL JSONB的匹配和交集問題

    這篇文章主要介紹了PostgreSQL JSONB的匹配和交集問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 初識PostgreSQL存儲過程

    初識PostgreSQL存儲過程

    這篇文章主要介紹了初識PostgreSQL存儲過程,本文講解了PostgreSQL中存儲過程的語法,并給出了一個操作實(shí)例,需要的朋友可以參考下
    2015-01-01
  • PostgreSQL慢SQL的定位排查方法

    PostgreSQL慢SQL的定位排查方法

    所謂慢SQL 是指在數(shù)據(jù)庫中執(zhí)行時間超過指定閾值的語句,慢查詢太多,對于業(yè)務(wù)而言,是有很大風(fēng)險的,可能隨時都會因?yàn)槟撤N原因而被觸發(fā),本篇文章將介紹 PostgreSQL 慢 SQL 如何定位排查,需要的朋友可以參考下
    2024-07-07
  • PostgreSql?JDBC事務(wù)操作方法詳解

    PostgreSql?JDBC事務(wù)操作方法詳解

    這篇文章主要為大家介紹了PostgreSql?JDBC事務(wù)操作方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 最新評論