PostgreSQL數(shù)據(jù)庫備份與恢復(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)境里重建。
- 備份單個數(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
文件中。
- 備份指定表 要是只想備份數(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ù)起死回生。
- 恢復(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ù)庫。
- 恢復(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ù)庫。
- 基礎(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ù)不一致。
- 增量物理備份 先完成一次基礎(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)文章希望大家以后多多支持腳本之家!
相關(guān)文章

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

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

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

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