校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > pgsql之pg_stat_replication的使用詳解

pgsql之pg_stat_replication的使用詳解

熱門標簽:移動外呼系統模擬題 廣州電銷機器人公司招聘 400電話申請客服 江蘇400電話辦理官方 天津開發區地圖標注app 地圖標注要花多少錢 電話機器人怎么換人工座席 濟南外呼網絡電話線路 電銷機器人能補救房產中介嗎

pg_stat_replication是一個視圖,主要用于監控一個基于流的設置,建議您 注意系統上稱作pg_stat_replication的視圖。(注:當前版本為pg 10.0,10.0以下版本,字段名會有差異)此視圖包含以下信息:

\d pg_stat_replication

每個字段代碼的含義:

pid 這代表負責流連接的wal_sender進程的進程ID。如果您在您的操作系統上檢查您進程表,您應該會找到一個帶有那個號碼的PostgreSQL進程。

usesysid 每個內部用戶都有一個獨一無二的編號。該系統的工作原理很像UNIX。 usesysid 是 (PostgreSQL) 用戶連接到系統的唯一標識符。

usename  (不是用戶名, 注意少了 r)它存儲與用戶相關的 usesysid 的名字。這是客戶端放入到連接字符串中的東西。

application_name這是同步復制的通常設置。它可以通過連接字符串傳遞到master。

client_addr它會告訴您流連接從何而來。它擁有客戶端的IP地址。

client_hostname除了客戶端的IP,您還可以這樣做,通過它的主機名來標識客戶端。您可以通過master上的postgresql.conf中的log_hostname啟用DNS反向查找。

client_port這是客戶端用來和WALsender進行通信使用的TPC端口號。 如果不本地UNIX套接字被使用了將顯示-1。

backend_start它告訴我們slave什么時間創建了流連接。

state此列告訴我們數據的連接狀態。如果事情按計劃進行,它應該包含流信息。

sent_lsn這代表發送到連接的最后的事務日志的位置。

write_lsn這是寫到standby系統磁盤上最后的事務日志位置。

flush_lsn這是被刷新到standby系統的最后位置。(這里注意寫和刷新之間的區別。寫并不意味著刷新 。)

replay_lsn這是slave上重放的最后的事務日志位置。

sync_priority這個字段是唯一和同步復制相關的。每次同步復制將會選擇一個優先權 —sync_priority—會告訴您選擇了那個優先權。

sync_state最后您會看到slave在哪個狀態。這個狀態可以是

async, sync, or potential。當有一個帶有較高優先權的同步slave時,PostgreSQL會把slave 標記為 potential。

在這個系統視圖中每個記錄只代表一個slave。因此,可以看到誰處于連接狀態,在做什么任務。pg_stat_replication也是檢查slave是否處于連接狀態的一個好方法。

上面說到pid代表負責流連接的wal_sender進程的進程ID,我們在機器上通過ps命令查看該進程的狀態:

ps -aux|grep 8225

在Linux上我們可以看到那個進程不僅有自己的作用 (在這種情況下, wal_sender),而且還帶有終端用戶的名字以及相關的網絡連接信息。在上圖中我們可以看到已經有人從192.168.47.127(對應pg_stat_replication的client_addr字段)通過51519(對應pg_stat_replication的client_port字段))端口連接到了master。

bonus:

上面我們提到replay_lsn是slave上重放的最后的事務日志位置。

pg_current_wal_lsn()函數的作用是獲取當前的wal log的寫位置。

pg_wal_lsn_diff()函數的作用是計算兩個wal日志之間的差距。

所以我們可以通過下面的方法獲取高可用架構下從庫的復制延遲情況:

 SELECT
   pg_wal_lsn_diff(A .c1, replay_lsn) /(1024 * 1024) AS slave_latency_MB
  FROM
   pg_stat_replication,
   pg_current_wal_lsn() AS A(c1)
  WHERE client_addr='%s' and application_name = '%s'
  ORDER BY
   slave_latency_MB
  LIMIT 1;

補充:PostgreSQL pg_stat_replication sync_state introduce

PostgreSQL 9.2引入同步復制后, pg_stat_replication的sync_state列有3種狀態.

sync

async

potential

分別代表同步standby, 異步standby, 可升級為同步的standby.

狀態來自以下函數 : pg_stat_get_wal_senders

[測試]

環境:

1個 primary, 3個 standby.

第一種配置 :

primary配置

postgresql.conf
synchronous_standby_names = 'test1,test2,test3'

standby1配置

primary_conninfo = 'application_name=test1 host=127.0.0.1 port=1999 user=postgres keepalives_idle=60'

standby2配置

primary_conninfo = 'application_name=test2 host=127.0.0.1 port=1999 user=postgres keepalives_idle=60'

standby3配置

primary_conninfo = 'application_name=test3 host=127.0.0.1 port=1999 user=postgres keepalives_idle=60'

primary查詢

digoal=# select pid,application_name,client_addr,sync_state from pg_stat_replication;
 pid | application_name | client_addr | sync_state 
------+------------------+-------------+------------
 6311 | test1   | 127.0.0.1 | sync
 6321 | test2   | 127.0.0.1 | potential
 6391 | test3   | 127.0.0.1 | potential
(3 rows)

如果sync節點掛掉, 按synchronous_standby_names的順序, 第一個potential節點會變成sync狀態.

pg_ctl stop -m fast -D /pgdata11999
digoal=# select pid,application_name,client_addr,sync_state from pg_stat_replication;
 pid | application_name | client_addr | sync_state 
------+------------------+-------------+------------
 6564 | test2   | 127.0.0.1 | sync
 6568 | test3   | 127.0.0.1 | potential
(2 rows)

當test1重新起來后又會變成sync狀態.

pg93@db-172-16-3-33-> pg_ctl start -D /pgdata11999
server starting
digoal=# select pid,application_name,client_addr,sync_state from pg_stat_replication;
 pid | application_name | client_addr | sync_state 
------+------------------+-------------+------------
 6564 | test2   | 127.0.0.1 | potential
 6605 | test1   | 127.0.0.1 | sync
 6568 | test3   | 127.0.0.1 | potential
(3 rows)

第二種配置 :

primary配置

synchronous_standby_names = 'test1,test2'

standby1配置不變

standby2配置不變

standby3配置不變

primary查詢

digoal=# select pid,application_name,client_addr,sync_state from pg_stat_replication;
 pid | application_name | client_addr | sync_state 
------+------------------+-------------+------------
 6470 | test1   | 127.0.0.1 | sync
 6472 | test3   | 127.0.0.1 | async
 6474 | test2   | 127.0.0.1 | potential
(3 rows)

test3變成異步了. 因為test3沒有配置在primary的synchronous_standby_names 中.

第三種配置 :

primary配置

synchronous_standby_names = 'test1'

standby1配置不變

standby2配置不變

standby3配置不變

primary查詢

digoal=# select pid,application_name,client_addr,sync_state from pg_stat_replication;
 pid | application_name | client_addr | sync_state 
------+------------------+-------------+------------
 6519 | test2   | 127.0.0.1 | async
 6521 | test3   | 127.0.0.1 | async
 6523 | test1   | 127.0.0.1 | sync
(3 rows)

test2,test3變成異步了. 因為test2,test3沒有配置在primary的synchronous_standby_names 中.

1. src/backend/replication/walsender.c

/*
 * Returns activity of walsenders, including pids and xlog locations sent to
 * standby servers.
 */
Datum
pg_stat_get_wal_senders(PG_FUNCTION_ARGS)
{
...略
   /*
    * More easily understood version of standby state. This is purely
    * informational, not different from priority.
    */
   if (sync_priority[i] == 0)
    values[7] = CStringGetTextDatum("async");
   else if (i == sync_standby)
    values[7] = CStringGetTextDatum("sync");
   else
    values[7] = CStringGetTextDatum("potential");
...略

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

您可能感興趣的文章:
  • PostgreSQL 恢復誤刪數據的操作
  • 在postgreSQL中運行sql腳本和pg_restore命令方式
  • PostgreSQL物理備份恢復之 pg_rman的用法說明

標簽:濮陽 杭州 昭通 溫州 榆林 辛集 寶雞 海西

巨人網絡通訊聲明:本文標題《pgsql之pg_stat_replication的使用詳解》,本文關鍵詞  pgsql,之,stat,replication,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pgsql之pg_stat_replication的使用詳解》相關的同類信息!
  • 本頁收集關于pgsql之pg_stat_replication的使用詳解的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产精品丝袜久久久久久app| 欧美无乱码久久久免费午夜一区| 亚洲电影视频在线| 亚洲综合小说图片| 一区二区三区国产| 伊人色综合久久天天| 一区二区三区在线观看动漫| 亚洲在线观看免费视频| 首页亚洲欧美制服丝腿| 日韩一区精品视频| 激情综合五月婷婷| 成人免费高清视频在线观看| 91视频免费看| 91精品国产欧美一区二区成人| 日韩一区二区三区电影| 国产日韩精品一区| 一区二区三区日韩欧美精品| 亚洲h动漫在线| 久草这里只有精品视频| 成人午夜免费视频| 欧美无砖专区一中文字| 欧美成人伊人久久综合网| 国产欧美日韩三区| 亚洲高清免费一级二级三级| 精品亚洲成av人在线观看| 成人午夜视频免费看| 精品视频在线免费看| 欧美精品一区二区不卡 | 青娱乐精品视频| 韩国理伦片一区二区三区在线播放| 大尺度一区二区| 4438x成人网最大色成网站| 久久久国产精品不卡| 亚洲线精品一区二区三区八戒| 卡一卡二国产精品 | 一区二区三区加勒比av| 免费人成在线不卡| 91免费在线播放| 久久这里只有精品视频网| 亚洲精品日日夜夜| 国产一区二区按摩在线观看| 欧美午夜精品一区二区蜜桃| 国产夜色精品一区二区av| 亚洲一区二区美女| 成人国产免费视频| 精品粉嫩aⅴ一区二区三区四区| 亚洲精品老司机| 国产精品夜夜嗨| 91麻豆精品国产91久久久更新时间 | 亚洲免费观看高清| 黄网站免费久久| 欧美日韩国产精品自在自线| 国产精品久久久久影视| 久久66热re国产| 欧美一区午夜视频在线观看| 亚洲人成网站色在线观看| 国产精品一区久久久久| 日韩欧美亚洲国产另类| 婷婷成人激情在线网| 在线观看不卡一区| 亚洲欧美日韩在线播放| caoporm超碰国产精品| 国产欧美视频一区二区| 国产精品自拍网站| 精品福利在线导航| 麻豆视频观看网址久久| 欧美日韩成人在线| 亚洲高清视频的网址| 欧美日韩久久久| 亚洲成人黄色影院| 色婷婷国产精品综合在线观看| 中文字幕五月欧美| gogo大胆日本视频一区| 日韩伦理电影网| av高清久久久| 亚洲女同一区二区| 色综合久久久久久久久久久| 亚洲精品自拍动漫在线| 91在线观看美女| 一区二区三区四区在线播放| 欧美在线观看18| 亚洲成人在线免费| 日韩小视频在线观看专区| 奇米在线7777在线精品| 精品少妇一区二区三区在线播放| 美女久久久精品| 国产亚洲婷婷免费| 91丝袜美女网| 天堂va蜜桃一区二区三区| 欧美一卡2卡三卡4卡5免费| 国产资源精品在线观看| 国产精品久久影院| 色偷偷久久人人79超碰人人澡| 午夜婷婷国产麻豆精品| 日韩欧美一级精品久久| 成人综合婷婷国产精品久久蜜臀 | 国产精品网站导航| 在线精品视频小说1| 免费高清在线视频一区·| 久久久久成人黄色影片| 日本高清不卡一区| 美女一区二区视频| 日韩久久一区二区| 欧美一级高清片| 99riav一区二区三区| 免费看欧美女人艹b| 国产精品久久久久毛片软件| 欧美日韩成人综合在线一区二区| 国产一区二区成人久久免费影院| 综合婷婷亚洲小说| 久久综合色婷婷| 欧美亚洲禁片免费| 国产精品18久久久久| 亚洲一区二区在线视频| 国产欧美一区二区三区鸳鸯浴 | 久久久99久久| 欧美午夜影院一区| 国产91丝袜在线18| 日韩 欧美一区二区三区| 中文字幕综合网| 久久久久国产免费免费| 在线播放视频一区| 99国产精品99久久久久久| 九九视频精品免费| 日韩黄色免费电影| 亚洲免费av观看| 国产午夜精品一区二区| 欧美一区二区在线看| 日本乱码高清不卡字幕| 国产999精品久久| 国产一区二区三区美女| 日韩精彩视频在线观看| 亚洲国产精品久久不卡毛片| 中文字幕一区二| 国产日韩欧美精品电影三级在线| 欧美电视剧在线观看完整版| 欧美日韩激情在线| 91黄色免费版| 色婷婷av一区二区三区大白胸 | 欧美一区二区国产| 欧美午夜在线观看| 在线观看亚洲专区| 欧洲一区二区三区免费视频| 99re免费视频精品全部| 国产sm精品调教视频网站| 激情欧美一区二区三区在线观看| 午夜精品一区二区三区免费视频| 一区二区成人在线视频 | 久久99蜜桃精品| 蜜桃91丨九色丨蝌蚪91桃色| 日韩和欧美一区二区三区| 欧美经典三级视频一区二区三区| 日韩欧美在线123| 久久国产综合精品| 麻豆精品一区二区| 久久精品999| 国产一区欧美日韩| 国产a区久久久| 成人av电影在线网| 一本色道亚洲精品aⅴ| 色8久久人人97超碰香蕉987| 欧美视频在线观看一区二区| 欧美影院一区二区三区| 制服丝袜亚洲精品中文字幕| 欧美一区二区成人6969| 久久久久久**毛片大全| 国产精品伦一区| 亚洲人吸女人奶水| 亚洲成人动漫在线免费观看| 欧美a一区二区| 成人一区二区在线观看| 欧洲av在线精品| 精品日产卡一卡二卡麻豆| 国产精品久久夜| 亚洲在线成人精品| 韩国理伦片一区二区三区在线播放| 国产一区二区精品久久91| 91一区二区在线| 欧美高清激情brazzers| 久久婷婷久久一区二区三区| 亚洲人成小说网站色在线| 美女看a上一区| av欧美精品.com| 91精品啪在线观看国产60岁| 国产视频一区在线播放| 亚洲国产日韩av| 国产激情91久久精品导航| 欧美吻胸吃奶大尺度电影| 久久只精品国产| 亚洲国产精品一区二区久久恐怖片| 蜜臀av性久久久久蜜臀aⅴ| 99久久综合国产精品| 91精品综合久久久久久| 国产精品每日更新| 青娱乐精品视频在线| 欧日韩精品视频| 国产精品麻豆网站| 激情深爱一区二区| 欧美精品一卡二卡| 亚洲欧美电影院|