亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Postgresql備份和增量恢復方案

 更新時間:2018年10月15日 10:32:16   作者:domac的菜園子  
這篇文章主要給大家介紹了關(guān)于Postgresql備份和增量恢復的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Postgresql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

最近工作上使用的數(shù)據(jù)庫一直是Postgresql,這是一款開源的數(shù)據(jù)庫,而且任何個人可以將該數(shù)據(jù)庫用于商業(yè)用途。在使用Postgresql的時候,讓我最明顯的感覺就是這數(shù)據(jù)庫做的真心好,雖然說數(shù)據(jù)庫的安裝包真的很小,但是性能和操作的便捷是一點也不輸給其他商業(yè)的大型數(shù)據(jù)庫,另外在命令行界面下對該數(shù)據(jù)庫直接進行操作的感覺真的是很爽。在使用數(shù)據(jù)庫的時候,我們作為小公司的數(shù)據(jù)庫管理員有一項工作是不可能避免的,那就是數(shù)據(jù)的備份和恢復問題。PostgreSQL雖然各個方面的有點很多,但是在數(shù)據(jù)庫備份這方面,它是不支持增量備份的,這點確實讓人覺得很是可惜啊。不過,瑕不掩瑜,總的來說這是一款很好的數(shù)據(jù)庫軟件。

之前,我們在 《Postgresql主從異步流復制方案》 一節(jié)中,部署了Postgresql的主從異步流復制環(huán)境。主從復制的目的是為了實現(xiàn)數(shù)據(jù)的備份,實現(xiàn)數(shù)據(jù)的高可用性和容錯行。下面主要簡單地介紹下我們運維Postgresql數(shù)據(jù)庫時的場景備份與恢復方案。

增量備份

PostgreSQL在做寫入操作時,對數(shù)據(jù)文件做的任何修改信息,首先會寫入WAL日志(預寫日志),然后才會對數(shù)據(jù)文件做物理修改。當數(shù)據(jù)庫服務器掉重啟時,PostgreSQL在啟動時會首先讀取WAL日志,對數(shù)據(jù)文件進行恢復。因此,從理論上講,如果我們有一個數(shù)據(jù)庫的基礎備份(也稱為全備),再配合WAL日志,是可以將數(shù)據(jù)庫恢復到任意時間點的。

上面的知識點很重要,因為我們場景的增量備份說白了就是通過基礎備份 + 增量WAL日志 進行重做恢復的。

增量備份設置

為了演示相關(guān)功能,我們基于 《Postgresql主從異步流復制方案》 一節(jié)中的環(huán)境pghost1服務器上,創(chuàng) 建相關(guān)管理目錄

切換到 postgres 用戶下

mkdir -p /data/pg10/backups
mkdir -p /data/pg10/archive_wals

backups目錄則可以用來存放基礎備份

archive_wals目錄自然用來存放歸檔了

接下來我們修改我們的postgresql.conf文件的相關(guān)設置

wal_level = replica

archive_mode = on

archive_command = '/usr/bin/lz4 -q -z %p /data/pg10/archive_wals/%f.lz4'

archive_command 參數(shù)的默認值是個空字符串,它的值可以是一條shell命令或者一個復雜的shell腳本。

在archive_command的shell命令或腳本中可以用 %p 表示將要歸檔的WAL文件的包含完整路徑信息的文件名,用 %f 代表不包含路徑信息的WAL文件的文件名。

修改wal_level和archive_mode參數(shù)都需要重新啟動數(shù)據(jù)庫才可以生效,修改archive_command不需要重啟,只需要reload即可,例如:

postgres=# SELECT pg_reload_conf();

postgres=# show archive_command ; 

創(chuàng)建基礎備份

我們使用之前介紹過的pg_basebackup命令進行基礎備份的創(chuàng)建, 基礎備份很重要,我們的數(shù)據(jù)恢復不能沒有它,建議我們根據(jù)相關(guān)業(yè)務策略,周期性生成我們的基礎備份。

$ pg_basebackup -Ft -Pv -Xf -z -Z5 -p 25432 -D /data/pg10/backups/

這樣,我們就成功生成我們的基礎數(shù)據(jù)備份了

設置還原點

一般我們需要根據(jù)重要事件發(fā)生時創(chuàng)建一個還原點,通過基礎備份和歸檔恢復到事件發(fā)生之前的狀態(tài)。

創(chuàng)建還原點的系統(tǒng)函數(shù)為:pg_create_restore_point,它的定義如下:

postgres=# SELECT pg_create_restore_point('domac-201810141800');

恢復到指定還原點

接下來,我們通過一個示例,讓我們的數(shù)據(jù)還原到我們設置的還原點上

首先,我們創(chuàng)建一張測試表:

CREATE TABLE test_restore(
 id SERIAL PRIMARY KEY,
 ival INT NOT NULL DEFAULT 0,
 description TEXT,
 created_time TIMESTAMPTZ NOT NULL DEFAULT now()
);

初始化一些測試數(shù)據(jù)作為基礎數(shù)據(jù),如下所示:

postgres=# INSERT INTO test_restore (ival) VALUES (1);
INSERT 0 1
postgres=# INSERT INTO test_restore (ival) VALUES (2);
INSERT 0 1
postgres=# INSERT INTO test_restore (ival) VALUES (3);
INSERT 0 1
postgres=# INSERT INTO test_restore (ival) VALUES (4);
INSERT 0 1

postgres=# select * from test_restore;
 id | ival | description |   created_time
----+------+-------------+-------------------------------
 1 | 1 |    | 2018-10-14 11:13:41.57154+00
 2 | 2 |    | 2018-10-14 11:13:44.250221+00
 3 | 3 |    | 2018-10-14 11:13:46.311291+00
 4 | 4 |    | 2018-10-14 11:13:48.820479+00
(4 rows)

并且按照上文的方法創(chuàng)建一個基礎備份。如果是測試,有一點需要注意,由于WAL文件是寫滿16MB才會進行歸檔,測試階段可能寫入會非常少,可以在執(zhí)行完 基礎備份之后,手動進行一次WAL切換。例如:

postgres=# select pg_switch_wal();
 pg_switch_wal
---------------
 0/1D01B858
(1 row)

或者通過設置archive_timeout參數(shù),在達到timeout閾值時強行切換到新的WAL段。

接下來,創(chuàng)建一個還原點,如下所示:

postgres=# select pg_create_restore_point('domac-1014');
 pg_create_restore_point
-------------------------
 0/1E0001A8
(1 row)

接下來我們對數(shù)據(jù)做一些變更, 我們刪除test_restore的所有數(shù)據(jù):

postgres=# delete from test_restore;
DELETE 4

下面進行恢復到名稱為“domac-1014”還原點的實驗,如下所示:

停止數(shù)據(jù)庫

$ pg_ctl stop -D /data/pg10/db

移除舊的數(shù)據(jù)目錄

$ rm -rf /data/pg10/db

$ mkdir db && chmod 0700 db

$ tar -xvf /data/pg10/backups/base.tar.gz -C /data/pg10/db

cp $PGHOME/share/recovery.conf.sample /pgdata/10/data/recovery.conf

chmod 0600 /pgdata/10/data/recovery.conf

修改 recovery.conf, 修改以下配置信息:

restore_command = '/usr/bin/lz4 -d /data/pg10/archive_wals/%f.lz4 %p'
recovery_target_name = 'domac-1014

然后啟動數(shù)據(jù)庫進入恢復狀態(tài),觀察日志,如下所示:

bash-4.2$ pg_ctl start -D /data/pg10/db
waiting for server to start....2018-10-14 11:26:56.949 UTC [8397] LOG: listening on IPv4 address "0.0.0.0", port 25432
2018-10-14 11:26:56.949 UTC [8397] LOG: listening on IPv6 address "::", port 25432
2018-10-14 11:26:56.952 UTC [8397] LOG: listening on Unix socket "/tmp/.s.PGSQL.25432"
2018-10-14 11:26:56.968 UTC [8398] LOG: database system was interrupted; last known up at 2018-10-14 09:26:59 UTC
2018-10-14 11:26:57.049 UTC [8398] LOG: starting point-in-time recovery to "domac-1014"
/data/pg10/archive_wals/00000002.history.lz4: No such file or directory
2018-10-14 11:26:57.052 UTC [8398] LOG: restored log file "00000002.history" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.077 UTC [8398] LOG: restored log file "000000020000000000000016" from archive
2018-10-14 11:26:57.191 UTC [8398] LOG: redo starts at 0/16000060
2018-10-14 11:26:57.193 UTC [8398] LOG: consistent recovery state reached at 0/16000130
2018-10-14 11:26:57.193 UTC [8397] LOG: database system is ready to accept read only connections
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.217 UTC [8398] LOG: restored log file "000000020000000000000017" from archive
 done
server started
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.384 UTC [8398] LOG: restored log file "000000020000000000000018" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.513 UTC [8398] LOG: restored log file "000000020000000000000019" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.699 UTC [8398] LOG: restored log file "00000002000000000000001A" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.805 UTC [8398] LOG: restored log file "00000002000000000000001B" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:57.982 UTC [8398] LOG: restored log file "00000002000000000000001C" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:58.116 UTC [8398] LOG: restored log file "00000002000000000000001D" from archive
/data/pg10/archive_w : decoded 16777216 bytes
2018-10-14 11:26:58.310 UTC [8398] LOG: restored log file "00000002000000000000001E" from archive
2018-10-14 11:26:58.379 UTC [8398] LOG: recovery stopping at restore point "domac-1014", time 2018-10-14 11:17:20.680941+00
2018-10-14 11:26:58.379 UTC [8398] LOG: recovery has paused
2018-10-14 11:26:58.379 UTC [8398] HINT: Execute pg_wal_replay_resume() to continue.

重啟后,我們對test_restore表進行查詢,看數(shù)據(jù)是否正常恢復:

postgres=# select * from test_restore;
 id | ival | description |   created_time
----+------+-------------+-------------------------------
 1 | 1 |    | 2018-10-14 11:13:41.57154+00
 2 | 2 |    | 2018-10-14 11:13:44.250221+00
 3 | 3 |    | 2018-10-14 11:13:46.311291+00
 4 | 4 |    | 2018-10-14 11:13:48.820479+00
(4 rows)

可以看到數(shù)據(jù)已經(jīng)恢復到指定的還原點:domac-1014。

這時,recovery.conf可以移除,避免下次數(shù)據(jù)重啟,數(shù)據(jù)再次恢復到該還原點

總結(jié)

備份和恢復是數(shù)據(jù)庫管理中非常重要的工作,日常運維中,我們需要根據(jù)需要進行相關(guān)策略的備份,并且周期性地進行恢復測試,保證數(shù)據(jù)的安全。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • PostgreSQL解析URL的方法

    PostgreSQL解析URL的方法

    盡管PostgreSQL中支持大量的數(shù)據(jù)類型,但是對于URL似乎并沒有一個相應的類型能夠去存儲。那么對于URL的數(shù)據(jù)我們在數(shù)據(jù)庫中要怎么去處理呢?今天通過本文給大家介紹下,需要的朋友參考下吧
    2021-07-07
  • PostgreSQL實現(xiàn)一個通用標簽系統(tǒng)

    PostgreSQL實現(xiàn)一個通用標簽系統(tǒng)

    這篇文章主要給大家介紹了關(guān)于利用PostgreSQL實現(xiàn)一個通用標簽系統(tǒng)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-01-01
  • PostgreSQL 中的postgres_fdw擴展詳解

    PostgreSQL 中的postgres_fdw擴展詳解

    這篇文章主要介紹了PostgreSQL 中的postgres_fdw擴展詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Postgres 創(chuàng)建Role并賦予權(quán)限的操作

    Postgres 創(chuàng)建Role并賦予權(quán)限的操作

    這篇文章主要介紹了 Postgres 創(chuàng)建Role并賦予權(quán)限的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 一文詳解PostgreSQL復制參數(shù)

    一文詳解PostgreSQL復制參數(shù)

    PostgreSQL 作為一款功能強大的開源關(guān)系型數(shù)據(jù)庫,其復制功能對于構(gòu)建高可用性系統(tǒng)至關(guān)重要,本文給大家詳細介紹了PostgreSQL的復制參數(shù),需要的朋友可以參考下
    2025-05-05
  • 如何為PostgreSQL的表自動添加分區(qū)

    如何為PostgreSQL的表自動添加分區(qū)

    這篇文章主要介紹了如何為PostgreSQL的表自動添加分區(qū),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • PostgreSQL教程(十一):服務器配置

    PostgreSQL教程(十一):服務器配置

    這篇文章主要介紹了PostgreSQL教程(十一):服務器配置,本文講解了服務器進程的啟動和關(guān)閉、服務器配置、內(nèi)存相關(guān)的參數(shù)配置等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • PostgreSQL操作json/jsonb方法詳解

    PostgreSQL操作json/jsonb方法詳解

    這篇文章主要給大家介紹了關(guān)于PostgreSQL操作json/jsonb的相關(guān)資料,PostgreSQL提供了兩種存儲JSON數(shù)據(jù)的類型:json和jsonb; jsonb是json的二進制形式,文中介紹的非常詳細,需要的朋友可以參考下
    2023-09-09
  • CentOS 9 Stream 上安裝 PostgreSQL 16的步驟

    CentOS 9 Stream 上安裝 PostgreSQL 16的步

    在CentOS9Stream上安裝PostgreSQL16,首先添加PostgreSQL官方倉庫,然后禁用系統(tǒng)自帶PostgreSQL版本,避免沖突,使用dnf命令安裝PostgreSQL16,并初始化數(shù)據(jù)庫,本文給大家介紹CentOS 9 Stream 上安裝 PostgreSQL 16的步驟,感興趣的朋友一起看看吧
    2024-11-11
  • PostgreSQL有效地處理數(shù)據(jù)的加密和解密的常見方法

    PostgreSQL有效地處理數(shù)據(jù)的加密和解密的常見方法

    在信息化建設和等保建設中,都要求實現(xiàn)對用戶數(shù)據(jù)的隱私保護,也就是我們常說的脫敏,那么在?PostgreSQL?數(shù)據(jù)庫中有沒有這樣的方法或者策略可以實現(xiàn)呢,本文小編將給大家介紹一下PostgreSQL有效地處理數(shù)據(jù)的加密和解密的常見方法,需要的朋友可以參考下
    2025-03-03

最新評論