PostgreSQL冷備份,需要在數(shù)據(jù)庫關(guān)閉狀態(tài)下,對(duì)數(shù)據(jù)文件進(jìn)行備份操作。盡管在一情況下并不適用,但并不妨礙我們?nèi)チ私馑奶匦浴?/span>
PostgreSQL熱備份,standby數(shù)據(jù)庫在應(yīng)用WAL日志的同時(shí),也可以提供只讀服務(wù),在oracle中叫activedataguard,在PostgreSQL中稱為hotstandby。在postgresql9.0以后的版本中,用戶可以在備用數(shù)據(jù)庫上進(jìn)行查詢、報(bào)表等操作,也可用做讀寫分離。在生產(chǎn)環(huán)境中,熱備一直備受追捧
今天,我們就來聊一聊PostgreSQL的冷備與熱備。
備份對(duì)象為數(shù)據(jù)庫集群主目錄$PGDATA,表空間目錄,事務(wù)日志(pg_log)目錄。當(dāng)然如果參數(shù)文件指定了其他目錄或文件,根據(jù)需要,也需要備份下來。
數(shù)據(jù)庫主目錄及所在位置
[telepg@test-telepg-01 ~]$ cd $PGDATA [telepg@test-telepg-01 data]$ pwd /app/pg/data_50_18802/data |
主目錄中的文件和文件夾
[telepg@test-telepg-01 data]$ ls -lrt -rwx------. 1 telepg telepg 3 Sep 27 08:39 PG_VERSION -rwx------. 1 telepg telepg 1636 Sep 27 08:39 pg_ident.conf drwx------. 10 telepg telepg 150 Nov 30 09:02 base drwx------. 3 telepg telepg 37 Nov 30 09:06 tbs_lh -rwx------. 1 telepg telepg 26809 Dec 1 11:08 postgresql.conf -rw-------. 1 telepg telepg 310 Dec 3 10:28 postgresql.auto.conf -rw-------. 1 telepg telepg 78 Dec 3 16:10 postmaster.opts -rw-------. 1 telepg telepg 13947 Dec 3 16:10 console.log -rw-------. 1 telepg telepg 86 Dec 3 16:10 postmaster.pid drwx------. 2 telepg telepg 10 Dec 3 16:10 pg_stat -rwx------. 1 telepg telepg 696 Dec 3 16:17 pg_hba.conf drwx------. 2 telepg telepg 4096 Dec 28 10:35 global drwx------. 2 telepg telepg 4096 Dec 28 10:36 pg_xact drwx------. 2 telepg telepg 8192 Dec 28 11:30 pg_subtrans drwx------. 2 telepg telepg 135168 Jan 1 17:36 pg_commit_ts drwx------. 3 telepg telepg 249856 Jan 27 11:53 pg_wal drwx------. 2 telepg telepg 8192 Feb 1 00:00 log -rw-------. 1 telepg telepg 44 Feb 1 00:00 current_logfiles drwx------. 4 telepg telepg 84 Feb 1 07:37 pg_logical drwx------. 2 telepg telepg 262 Feb 1 08:25 pg_stat_tmp |
近期事務(wù)日志目錄
[telepg@test-telepg-01 data]$ cd log [telepg@test-telepg-01 log]$ ls -lrt -rw-------. 1 telepg telepg 14978379 Jan 29 00:00 postgresql-2021-01-28_000000.log -rw-------. 1 telepg telepg 14979822 Jan 30 00:00 postgresql-2021-01-29_000000.log -rw-------. 1 telepg telepg 14975700 Jan 31 00:00 postgresql-2021-01-30_000000.log -rw-------. 1 telepg telepg 14984205 Feb 1 00:00 postgresql-2021-01-31_000000.log -rw-------. 1 telepg telepg 5268099 Feb 1 08:26 postgresql-2021-02-01_000000.log |
表空間目錄
[telepg@test-telepg-01 data]$ cd tbs_lh [telepg@test-telepg-01 tbs_lh]$ ls -lrt drwx------. 2 telepg telepg 10 Nov 30 09:06 PG_12_201909212 |
備份需要提前準(zhǔn)備好所需要的空間,可以是本地的,也可以是異地的存儲(chǔ)。
查看數(shù)據(jù)庫的大小:
lh=# select round(sum(pg_database_size(oid))/1024/1024/1024.0,2)||GB from pg_database; column ---------- 329.86GB |
準(zhǔn)備好可以放下整個(gè)備份的目錄
[telepg@test-telepg-01 data]$ df -h /dev/sdb 55T 1.1T 54T 2% /app |
停庫
[telepg@test-telepg-01 ~]$ pg_ctl stop -m fast waiting for server to shut down.... done server stopped |
備份$PGDATA,排除pg_xlog,pg_log以及不需要備份的目錄pgbak.
rsync -acvz -L --exclude "pg_xlog" --exclude "pgbak" --exclude "pg_log" $PGDATA /app/pg/data_50_18802/data/pgbackup/ |
備份pg_xlog
[telepg@test-telepg-01 ~]$ pg_controldata |grep checkpoint Latest checkpoint location: 125/32D4DF90 Latest checkpoints REDO location: 125/32D4DF58 Latest checkpoints REDO WAL file: 000000010000012500000032 Latest checkpoints TimeLineID: 1 Latest checkpoints PrevTimeLineID: 1 Latest checkpoints full_page_writes: on Latest checkpoints NextXID: 0:830624231 Latest checkpoints NextOID: 2120456 Latest checkpoints NextMultiXactId: 1 Latest checkpoints NextMultiOffset: 0 Latest checkpoints oldestXID: 632099619 Latest checkpoints oldestXIDs DB: 1449363 Latest checkpoints oldestActiveXID: 830624231 Latest checkpoints oldestMultiXid: 1 Latest checkpoints oldestMultis DB: 17823 Latest checkpoints oldestCommitTsXid:632099619 Latest checkpoints newestCommitTsXid:830624230 Time of latest checkpoint: Mon 01 Feb 2021 08:37:49 AM CST |
在備份目錄中創(chuàng)建pg_xlog目錄并修改權(quán)限
[telepg@test-telepg-01 ~]$rsync -acvz -L --exclude "pg_xlog" --exclude "pgbak" --exclude "pg_log" $PGDATA /app/pg/data_50_18802/data/pgbackup/ [telepg@test-telepg-01 ~]$chmod 777 /app/pg/data_50_18802/data/pgbackup/pg_xlog |
查找需要的pg_xlog文件
[telepg@test-telepg-01 ~]$ cd $PGDATA [telepg@test-telepg-01~]$ls -lrt $PGDATA/pgbackup/pg_xlog/000000030000000E000000E* -rw------- 1 pg93 pg93 16M Feb 1 12:24 /pgdata1999/pg_xlog/000000030000000E000000EA -rw------- 1 pg93 pg93 16M Feb 1 12:24 /pgdata1999/pg_xlog/000000030000000E000000EB |
拷貝需要的pg_xlog文件
[telepg@test-telepg-01~]$cp`$PGDATA/pg_xlog/000000030000000E000000EB/pgdata/digoal/1921/data04/pg93backup/pgdata1999/pg_xlog/ |
檢查備份目錄,是否備份正常
[telepg@test-telepg-01 data]$ ll -rwx------. 1 telepg telepg 3 Sep 27 08:39 PG_VERSION -rwx------. 1 telepg telepg 1636 Sep 27 08:39 pg_ident.conf drwx------. 10 telepg telepg 150 Nov 30 09:02 base drwx------. 3 telepg telepg 37 Nov 30 09:06 tbs_lh -rwx------. 1 telepg telepg 26809 Dec 1 11:08 postgresql.conf -rw-------. 1 telepg telepg 310 Dec 3 10:28 postgresql.auto.conf -rw-------. 1 telepg telepg 78 Dec 3 16:10 postmaster.opts -rw-------. 1 telepg telepg 13947 Dec 3 16:10 console.log -rw-------. 1 telepg telepg 86 Dec 3 16:10 postmaster.pid drwx------. 2 telepg telepg 10 Dec 3 16:10 pg_stat -rwx------. 1 telepg telepg 696 Dec 3 16:17 pg_hba.conf drwx------. 2 telepg telepg 4096 Dec 28 10:35 global drwx------. 2 telepg telepg 4096 Dec 28 10:36 pg_xact drwx------. 2 telepg telepg 8192 Dec 28 11:30 pg_subtrans drwx------. 2 telepg telepg 135168 Jan 1 17:36 pg_commit_ts drwx------. 3 telepg telepg 249856 Jan 27 11:53 pg_wal drwx------. 2 telepg telepg 8192 Feb 1 00:00 log -rw-------. 1 telepg telepg 44 Feb 1 00:00 current_logfiles drwx------. 4 telepg telepg 84 Feb 1 07:37 pg_logical drwx------. 2 telepg telepg 262 Feb 1 08:25 pg_stat_tmp |
PostgreSQL9.0之后的版本中,日志傳送的方法有以下兩種:
基于文件(base_file)的傳送方式:服務(wù)器寫完一個(gè)WAL日志文件后,再把WAL日志文件拷貝到standby數(shù)據(jù)庫上去應(yīng)用。
流復(fù)制(streamingreplication)的方式:這是PostgreSQL9.0才提供的新方法,在事務(wù)提交后,就會(huì)把生成的日志異步的傳送到standby數(shù)據(jù)庫上應(yīng)用,這比基本文件的日志傳送方法有更低的數(shù)據(jù)延遲。
今天主要聊一聊流復(fù)制熱備方式。
PostgreSQL9.0之后的版本中引入了主從的流復(fù)制機(jī)制,,從服務(wù)器通過tcp流從主服務(wù)器中同步相應(yīng)的數(shù)據(jù)。流復(fù)制允許備庫更新,同時(shí)也能提供只讀服務(wù),流復(fù)制默認(rèn)是異步的。
流復(fù)制架構(gòu)圖
實(shí)例準(zhǔn)備
role | ip | port | version |
Main | 192.168.122.1 | 18802 | 12.3 |
Slave | 192.168.122.2 | 18802 | 12.3 |
首先我們需要對(duì)主庫進(jìn)行配置,創(chuàng)建復(fù)制用戶repuser,并賦予復(fù)制和登錄的權(quán)限。
lh=# create user repuser replication login connection limit 2 encrypted password repuser; CREATE ROLE |
更新認(rèn)證方式,編輯配置文件編輯配置文件pg_hba.conf,新增以下IP
host all all 0.0.0.0/0 scram-sha-256 host all all ::/0 scram-sha-256 |
編輯配置文件postgresql.conf
listen_addresses = * wal_log_hints = on archive_mode = on archive_command = cp %p /var/lib/pgsql/12/pg_archive/%f wal_keep_segments = 64 |
新增歸檔目錄pg_archive
[telepg@test-telepg-01 data]$mkdir /var/lib/pgsql/12/pg_archive |
重啟主庫
[telepg@test-telepg-01 data]$systemctl restart postgresql-12.3 |
配置從庫
在postgres用戶根目錄下創(chuàng)建.pgpass文件,并追加認(rèn)證信息
[telepg@test-telepg-01 data]touch .pgpass [telepg@test-telepg-01 data]chmod 777 .pgpass [telepg@test-telepg-01 data]cat .pgpass 192.168.122.1:18802:lh:repuser:repuser |
從主節(jié)點(diǎn)拷貝數(shù)據(jù)到從節(jié)點(diǎn)
$ su - telepg Last login: Mon Feb 1 14:27:20 CST 2021 on pts/0 $ pg_basebackup -h 192.168.122.1 -U repuser -D /var/lib/pgsql/12/data/ -X stream -P Password: 24308/24308 kB (100%), 1/1 tablespace |
拷貝配置文件recovery.conf.sample為recovery.conf
[telepg@test-telepg-01data]$cp`/usr/pgsql-12/share/recovery.conf.sample/var/lib/pgsql/12/data/recovery.conf |
更新配置文件recovery.conf
standby_mode = on primary_conninfo = host=192.168.122.1 port=18802 user=repuser password=repuser recovery_target_timeline = latest |
重啟從庫
[telepg@test-telepg-01data]$systemctl restart postgresql-12.3 |
在主節(jié)點(diǎn)上命令驗(yàn)證
lh=# select application_name, client_addr, sync_state from pg_stat_replication; application_name | client_addr | sync_state ------------------+---------------+------------ walreceiver | 192.168.122.2 | async (1 row) |
說明192.168.122.2是從服務(wù)器,在接收流,而且是異步流復(fù)制??梢苑直嬖谥?、從節(jié)點(diǎn)上查看進(jìn)程來進(jìn)行驗(yàn)證
主服務(wù)器上有一個(gè)walsender 進(jìn)程
[telepg@test-telepg-01data]$$ ps -ef | grep postgres postgres 20645 19653 0 2021 ? 00:00:00 postgres: wal sender process repuser 192.168.122.2(59176) streaming 0/70029E0 |
從服務(wù)器上有一個(gè)walsender 進(jìn)程
[telepg@test-telepg-01data]$$ $ ps -ef | grep postgres postgres 18019 18012 0 2021 ? 00:00:00 postgres: wal receiver process streaming 0/7002A18 |
END
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/130006.html
摘要:作者譚峰張文升出版日期年月頁數(shù)頁定價(jià)元本書特色中國(guó)開源軟件推進(jìn)聯(lián)盟分會(huì)特聘專家撰寫,國(guó)內(nèi)多位開源數(shù)據(jù)庫專家鼎力推薦。張文升中國(guó)開源軟件推進(jìn)聯(lián)盟分會(huì)核心成員之一。 很高興《PostgreSQL實(shí)戰(zhàn)》一書終于出版,本書大體上系統(tǒng)總結(jié)了筆者 PostgreSQL DBA 職業(yè)生涯的經(jīng)驗(yàn)總結(jié),本書的另一位作者張文升擁有豐富的PostgreSQL運(yùn)維經(jīng)驗(yàn),目前就職于探探科技任首席PostgreS...
摘要:硬盤硬盤硬盤云數(shù)據(jù)庫的硬盤大小。用戶可以根據(jù)對(duì)云數(shù)據(jù)庫的硬件需求進(jìn)行選擇。云數(shù)據(jù)庫提供自動(dòng)備份和手動(dòng)備份兩種方式,防止數(shù)據(jù)丟失,避免誤操作帶來的風(fēng)險(xiǎn)。日志日志日志日志是用于記錄云數(shù)據(jù)庫操作事件的記錄文件。 主要概念本篇目錄實(shí)例類型版本數(shù)據(jù)庫機(jī)型內(nèi)存硬盤付費(fèi)方式數(shù)量節(jié)點(diǎn)配置文件管理員實(shí)例名稱資源IDIP和端口備份日志實(shí)例類型PostgreSQL實(shí)例目前支持普通版和高可用版實(shí)例。版本Postgr...
摘要:指定要用于查找的口令文件的名稱。前四個(gè)字段可以是確定的字面值,也可以使用通配符匹配所有。利用環(huán)境變量引用的文件權(quán)限也要滿足這個(gè)要求,否則同樣會(huì)被忽略。在上,該文件被假定存儲(chǔ)在一個(gè)安全的目錄中,因此不會(huì)進(jìn)行特別的權(quán)限檢查。 pg_dump pg_dump 把一個(gè)數(shù)據(jù)庫轉(zhuǎn)儲(chǔ)為純文本文件或者是其它格式. 用法: pg_dump [選項(xiàng)]... [數(shù)據(jù)庫名字] 一般選項(xiàng): -f, --fi...
閱讀 1356·2023-01-11 13:20
閱讀 1707·2023-01-11 13:20
閱讀 1215·2023-01-11 13:20
閱讀 1906·2023-01-11 13:20
閱讀 4165·2023-01-11 13:20
閱讀 2757·2023-01-11 13:20
閱讀 1402·2023-01-11 13:20
閱讀 3671·2023-01-11 13:20