您好,登錄后才能下訂單哦!
本篇內容主要講解“PostgreSQL 12搭建流復制的過程是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“PostgreSQL 12搭建流復制的過程是什么”吧!
主庫
創建復制用戶
[pg12@localhost pg120db]$ psql -c "CREATE USER replicator WITH REPLICATION ENCRYPTED PASSWORD 'test'" -d testdb Timing is on. Expanded display is used automatically. CREATE ROLE Time: 30.796 ms
常規參數配置
[pg12@localhost pg120db]$ grep 'listen' postgresql.conf listen_addresses = '*' # what IP address(es) to listen on; pg12@localhost pg120db]$ grep 'replication' pg_hba.conf # DATABASE can be "all", "sameuser", "samerole", "replication", a # keyword does not match "replication". Access to replication # "all", "sameuser", "samerole" or "replication" makes the name lose # Allow replication connections from localhost, by a user with the # replication privilege. local replication all trust host replication all 127.0.0.1/32 trust host replication all 192.168.0.0/16 md5 host replication all ::1/128 trust [pg12@localhost pg120db]$
重新加載配置參數
[pg12@localhost pg120db]$ psql -c "select pg_reload_conf()" -d testdb Timing is on. Expanded display is used automatically. pg_reload_conf ---------------- t (1 row) Time: 454.580 ms
確認該庫為master主庫
[pg12@localhost pg120db]$ psql -c "select pg_is_in_recovery()" -d testdb Timing is on. Expanded display is used automatically. pg_is_in_recovery ------------------- f (1 row) Time: 23.530 ms [pg12@localhost pg120db]$
備庫
使用pg_basebackup執行主庫備份
[pg12@localhost ~]$ pg_basebackup -h 192.168.26.28 -U replicator -p 5432 -D $PGDATA -Fp -Xs -P -R Password: 426401/9113562 kB (4%), 0/1 tablespace
其中-Fp表示以plain格式數據,-Xs表示以stream方式包含所需的WAL文件,-P表示顯示進度,-R表示為replication寫配置信息。
備份完成,使用-R選項,在data目錄下自動生成standby.signal“信號”文件(可手工使用touch命令生成)以及更新了postgresql.auto.conf文件,postgresql.auto.conf中寫入了主庫的連接信息(可手工添加primary_conninfo信息)。
[pg12@localhost ~]$ pg_basebackup -h 192.168.26.28 -U replicator -p 5432 -D $PGDATA -Fp -Xs -P -R Password: 9113571/9113571 kB (100%), 1/1 tablespace [pg12@localhost ~]$ [pg12@localhost ~]$ cd $PGDATA [pg12@localhost testdb]$ ls backup_label pg_commit_ts pg_log pg_replslot pg_stat_tmp PG_VERSION postgresql.conf base pg_dynshmem pg_logical pg_serial pg_subtrans pg_wal standby.signal current_logfiles pg_hba.conf pg_multixact pg_snapshots pg_tblspc pg_xact global pg_ident.conf pg_notify pg_stat pg_twophase postgresql.auto.conf [pg12@localhost testdb]$ ll standby.signal -rw-------. 1 pg12 pg12 0 Nov 12 16:35 standby.signal [pg12@localhost testdb]$ [pg12@localhost testdb]$ cat postgresql.auto.conf # Do not edit this file manually! # It will be overwritten by the ALTER SYSTEM command. primary_conninfo = 'user=replicator password=test host=192.168.26.28 port=5432 sslmode=prefer sslcompression=0 gssencmode=prefer krbsrvname=postgres target_session_attrs=any' [pg12@localhost testdb]$ [pg12@localhost testdb]$ grep 'primary_conninfo' postgresql.* postgresql.auto.conf:primary_conninfo = 'user=replicator password=test host=192.168.26.28 port=5432 sslmode=prefer sslcompression=0 gssencmode=prefer krbsrvname=postgres target_session_attrs=any' postgresql.conf:#primary_conninfo = '' # connection string to sending server [pg12@localhost testdb]$
在PG 11中,需要創建recovery.conf文件,在此文件中配置standby_mode和primary_conninfo參數,PG 12已不再需要該文件,改為standby.signal文件以及通過配置參數直接設置。
備庫啟動數據庫,通過pg_is_in_recovery確認是否正常配置
[pg12@localhost testdb]$ pg_ctl -D $PGDATA start waiting for server to start....2019-11-12 16:46:31.635 CST [20436] LOG: starting PostgreSQL 12.0 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-36), 64-bit 2019-11-12 16:46:31.636 CST [20436] LOG: listening on IPv4 address "0.0.0.0", port 5432 2019-11-12 16:46:31.636 CST [20436] LOG: listening on IPv6 address "::", port 5432 2019-11-12 16:46:31.638 CST [20436] LOG: listening on Unix socket "/tmp/.s.PGSQL.5432" 2019-11-12 16:46:31.750 CST [20436] LOG: redirecting log output to logging collector process 2019-11-12 16:46:31.750 CST [20436] HINT: Future log output will appear in directory "pg_log". done server started [pg12@localhost testdb]$ psql -c "select pg_is_in_recovery()" -d testdb pg_is_in_recovery ------------------- t (1 row) [pg12@localhost testdb]$
完成搭建
通過pg_stat_replication可查詢復制狀態(異步復制)
[pg12@localhost pg120db]$ psql -x -c "select * from pg_stat_replication" -d testdb Timing is on. Expanded display is used automatically. -[ RECORD 1 ]----+------------------------------ pid | 4503 usesysid | 155959 usename | replicator application_name | walreceiver client_addr | 192.168.26.25 client_hostname | client_port | 35172 backend_start | 2019-11-12 16:46:31.000236+08 backend_xmin | state | streaming sent_lsn | 6/A3000148 write_lsn | 6/A3000148 flush_lsn | 6/A3000148 replay_lsn | 6/A3000148 write_lag | flush_lag | replay_lag | sync_priority | 0 sync_state | async reply_time | 2019-11-12 16:48:32.509887+08 Time: 149.682 ms [pg12@localhost pg120db]$
到此,相信大家對“PostgreSQL 12搭建流復制的過程是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。