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

PostgreSQL 流復制異步轉同步的操作

 更新時間:2020年12月31日 08:40:55   作者:董董-醬  
這篇文章主要介紹了PostgreSQL 流復制異步轉同步的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

非常重要的synchronous_commit參數(shù)

流復制的同步方式,有主庫配置文件postgresql.conf,中的synchronous_commit控制著。所以理解該參數(shù)的配置十分重要。

單實例環(huán)境

參數(shù)值 說明 優(yōu)點 缺點
on 或 local 當事務提交時,WAL先寫入WAL buffer 再寫到 WAL文件(落盤)中。設置為on表示提交事務時需要等待本地WAL最終落盤后,才向客戶端返回成功。 非常安全 數(shù)據(jù)庫性能有損耗
off 當事務提交時,不需要等待WAL先寫入WAL buffer 再寫到 WAL文件(落盤)中。 提升數(shù)據(jù)庫性能 數(shù)據(jù)庫宕機是最新提交的少量事務可能丟失

流復制環(huán)境

參數(shù)值 說明 優(yōu)點 缺點
remote_write 當主庫提交事務后,需等待備庫接收主庫發(fā)送的WAL日志流并寫入WAL buffer, 就向客戶端返回成功 只有主庫的WAL是落盤的 事務響應時間快
on 當主庫提交事務后,需等待備庫接收主庫發(fā)送的WAL日志流并寫入WAL buffer 以及寫入WAL文件, 就向客戶端返回成功 主、備庫WAL均落盤,有兩份持有化文件保護 事務響應時間相對較慢
remote_apply 當主庫提交事務后,需等待備庫接收主庫發(fā)送的WAL日志流并寫入WAL buffer 以及寫入WAL文件, 同時備庫apply之后, 就向客戶端返回成功 數(shù)據(jù)保護最好 影響事務性能

查看同步情況

在主庫執(zhí)行以下SQL , sync_state字段為async表示異步同步方式

postgres=# select usename , application_name , client_addr,sync_state from pg_stat_replication;
 usename | application_name | client_addr | sync_state 
---------+------------------+----------------+------------
 repuser | walreceiver | 192.168.56.102 | async
(1 row)

配置同步復制

主庫配置postgresql.conf文件

[postgres@pg01 data]$ vi postgresql.conf 
synchronous_commit = on
synchronous_standby_names = 'walreceiver'

synchronous_commit : 開篇提到的那個重要參數(shù)!

synchronous_standby_names: 這里的name填寫,剛剛查詢到的application_name。

重啟主庫服務

[root@pg01 PG_12_201909212]# service postgresql-12 restart
Stopping postgresql-12 service:    [ OK ]
Starting postgresql-12 service:    [ OK ]

再次查看主庫字典

postgres=# select usename , application_name , client_addr,sync_state from pg_stat_replication;
 usename | application_name | client_addr | sync_state 
---------+------------------+----------------+------------
 repuser | walreceiver | 192.168.56.102 | sync

數(shù)據(jù)保護測試

關閉備庫。模擬備庫宕機無法正常接收WAL

[root@pg02 ~]# service postgresql-12 stop
Stopping postgresql-12 service:    [ OK ]

主庫嘗試進行DML操作

dong=# insert into t1 select * from t1;
Cancel request sent
WARNING: canceling wait for synchronous replication due to user request
DETAIL: The transaction has already committed locally, but might not have been replicated to the standby.
INSERT 0 8

由于備庫已關閉,無法接受從主庫傳來的WAL,根據(jù)同步規(guī)則,主庫需要一直等待主庫接收到WAL的消息。

手動進行了cancel, 數(shù)據(jù)庫報錯。說明在等待備庫reguest相應。

所以,sync同步模式雖然可以很好的保護數(shù)據(jù),但同時也帶來了性能的影響,需慎重

補充:PostgreSQL 流復制數(shù)據(jù)同步檢查

如何分辨主、備

看進程

主庫 – walwriter

[root@pg01 PG_12_201909212]# ps -ef| grep wal
postgres 21157 21151 0 15:57 ?  00:00:00 postgres: walwriter         
postgres 21168 21151 0 15:57 ?  00:00:00 postgres: walsender repuser 192.168.56.102(38473) streaming 0/2A0001C0

備庫 – walreceiver

[root@pg02 ~]# ps -ef | grep wal
postgres 13383 13369 0 14:08 ?  00:00:01 postgres: walreceiver streaming 0/2A0001C0   

函數(shù)方法

一句話判斷哪個是主庫、哪個是備庫,返回的值:

f 為主庫

t 為備庫

postgres=# select pg_is_in_recovery();
 pg_is_in_recovery 
-------------------
 f
(1 row)

那我這個就是主庫嘍~

檢查流復制同步情況

先確定主庫傳到哪兒了

在確定備庫接收到哪兒了

最后確定備庫應用到哪兒了

檢查主庫傳輸

確定主庫傳到什么位置了

postgres=# select pg_current_wal_lsn();
 pg_current_wal_lsn 
--------------------
 0/2A0001C0
(1 row)

檢查備庫恢復

確定備庫接收到哪兒了

postgres=# select pg_last_wal_receive_lsn();
 pg_last_wal_receive_lsn 
-------------------------
 0/2A0001C0
(1 row)

確定備庫應用到哪兒了

postgres=# select pg_last_wal_replay_lsn();
 pg_last_wal_replay_lsn 
------------------------
 0/2A0001C0
(1 row)

最近事務應用的時間

postgres=# select pg_last_xact_replay_timestamp();
 pg_last_xact_replay_timestamp 
-------------------------------
 2020-03-05 15:20:22.125688+08
(1 row)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • postgresql查詢自動將大寫的名稱轉換為小寫的案例

    postgresql查詢自動將大寫的名稱轉換為小寫的案例

    這篇文章主要介紹了postgresql查詢自動將大寫的名稱轉換為小寫的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Ubuntu中卸載Postgresql出錯的解決方法

    Ubuntu中卸載Postgresql出錯的解決方法

    這篇文章主要給大家介紹了關于在Ubuntu中卸載Postgresql出錯的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-09-09
  • PostgreSQL中如何將對象oid和對象名相互轉換

    PostgreSQL中如何將對象oid和對象名相互轉換

    文章介紹了在PostgreSQL中如何使用內(nèi)部數(shù)據(jù)類型將對象OID(對象標識符)轉換為對象名,從而簡化系統(tǒng)視圖的關聯(lián)查詢,文章還提供了不同類型OID與對象名之間的轉換關系,并通過示例展示了如何將對象名轉換為OID
    2024-11-11
  • 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事務回卷實戰(zhàn)案例詳析

    PostgreSQL事務回卷實戰(zhàn)案例詳析

    前段時間在公司小范圍做了一個關于PG事務實現(xiàn)的講座,最后總結了一個摘要性的東西,分享一下,這篇文章主要給大家介紹了關于PostgreSQL事務回卷實戰(zhàn)案例的相關資料,需要的朋友可以參考下
    2022-03-03
  • 關于PostgreSQL JSONB的匹配和交集問題

    關于PostgreSQL JSONB的匹配和交集問題

    這篇文章主要介紹了PostgreSQL JSONB的匹配和交集問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 關于PostgreSql數(shù)據(jù)庫與mysql數(shù)據(jù)庫的不同點以及注意事項

    關于PostgreSql數(shù)據(jù)庫與mysql數(shù)據(jù)庫的不同點以及注意事項

    PostgreSQL和MySQL是兩種流行的關系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS),它們都可以用來存儲和管理數(shù)據(jù),但是它們在某些方面有所不同,下面這篇文章主要給大家介紹了關于PostgreSql數(shù)據(jù)庫與mysql數(shù)據(jù)庫的不同點以及注意事項的相關資料,需要的朋友可以參考下
    2023-05-05
  • PostgreSQL的upsert實例操作(insert on conflict do)

    PostgreSQL的upsert實例操作(insert on conflict do)

    這篇文章主要介紹了PostgreSQL的upsert實例操作(insert on conflict do),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL歸檔配置及自動清理歸檔日志的操作

    PostgreSQL歸檔配置及自動清理歸檔日志的操作

    這篇文章主要介紹了PostgreSQL歸檔配置及自動清理歸檔日志的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • postgresql關于like%xxx%的優(yōu)化操作

    postgresql關于like%xxx%的優(yōu)化操作

    這篇文章主要介紹了postgresql關于like%xxx%的優(yōu)化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01

最新評論