欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

postgresql邏輯復(fù)制的實(shí)現(xiàn)

 更新時(shí)間:2025年06月16日 09:50:57   作者:24K老游  
本文介紹PostgreSQL邏輯復(fù)制實(shí)現(xiàn),基于發(fā)布訂閱模型,需設(shè)置WAL_LEVEL為logical,支持跨庫(kù)備份,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

如果要將不同庫(kù)的某關(guān)鍵表備份到指定庫(kù)里,可以用邏輯復(fù)制完成相關(guān)功能。

邏輯復(fù)制基本概念

PG邏輯復(fù)制基于發(fā)布和訂閱模型,一個(gè)發(fā)布可以有多個(gè)訂閱者。
發(fā)布publication可以創(chuàng)建在任意單機(jī)上,也可以在物理復(fù)制的主庫(kù)上,發(fā)布端要求數(shù)據(jù)庫(kù)參數(shù)WAL_LEVEL為logical。一個(gè)發(fā)布可以被多個(gè)數(shù)據(jù)庫(kù)訂閱。一個(gè)發(fā)布只能包含一個(gè)數(shù)據(jù)庫(kù)中的表,但是這些表可以分布在不同的schema下。

訂閱處于邏輯復(fù)制的下游端,一個(gè)訂閱只能對(duì)應(yīng)一個(gè)發(fā)布。訂閱端的數(shù)據(jù)庫(kù)名可以跟發(fā)布端不同,但是訂閱發(fā)布的表名和schema必須相同。

當(dāng)訂閱創(chuàng)建成功后,就會(huì)自動(dòng)在發(fā)布端創(chuàng)建多個(gè)邏輯復(fù)制槽,其中一個(gè)用于后續(xù)的增量數(shù)據(jù)同步,永久保留,另外還會(huì)創(chuàng)建一個(gè)或者多個(gè)的臨時(shí)復(fù)制槽,用于復(fù)制表的全量快照數(shù)據(jù)。
是當(dāng)發(fā)布端是物理復(fù)制架構(gòu)時(shí),如果發(fā)生主從切換,發(fā)布是不會(huì)跟隨數(shù)據(jù)庫(kù)failover的。但是可以通過(guò)手工拷貝文件或者利用插件實(shí)現(xiàn)。

邏輯復(fù)制的限制

(1)數(shù)據(jù)庫(kù)的表結(jié)構(gòu)不會(huì)被復(fù)制,所以需要在訂閱端先創(chuàng)建對(duì)應(yīng)的schema和表
(2)TRUNCATE和DDL不會(huì)復(fù)制,如果要進(jìn)行DDL變更,需要先在訂閱端執(zhí)行DDL,然后在發(fā)布端執(zhí)行。
(3)Sequence不會(huì)不復(fù)制,當(dāng)發(fā)布端使用了sequence數(shù)據(jù),其寫入了表的值會(huì)同步到訂閱端,但是目標(biāo)庫(kù)的sequence并不會(huì)發(fā)生變化。
(4)不支持大對(duì)象。
(5)復(fù)制只能是基表到基表,不支持視圖、物化視圖、外部表等。如果表是分區(qū)表,需要基于分區(qū)進(jìn)行復(fù)制。

測(cè)試

  • 發(fā)布和訂閱端都新建相同的表t1,t2
  • 發(fā)布端為t1創(chuàng)建發(fā)布
  • 訂閱端為t1創(chuàng)建訂閱
新建一個(gè)庫(kù),做為訂閱端
[pg@localhost data]$ pg_ctl init -D /data/db3

發(fā)布與訂閱端都建相關(guān)同步結(jié)構(gòu)的表t1,t2
postgres=# create table t1(id int,name varchar(20));
CREATE TABLE
postgres=# create table t2(id int,name varchar(20));
CREATE TABLE

在發(fā)布端為t1創(chuàng)建發(fā)布

修改發(fā)布端wal_level = logical,修改后要restart訂閱端,reload不生效。
postgres=# show wal_level;
 wal_level
-----------
 logical
(1 row)


postgres=# create publication pub_test for table t1;
CREATE PUBLICATION

在訂閱端為t1創(chuàng)建訂閱

注:訂閱端有wal_level也必須是logical

postgres=# create subscription sub_test connection 'host=127.0.0.1 port=15431 dbname=postgres user=pg' publication pub_test;
NOTICE:  created replication slot "sub_test" on publisher
CREATE SUBSCRIPTION

觀察同步效果

在發(fā)布端分別向 t1 t2表插入數(shù)據(jù)
postgres=# insert into t1(id,name) values (1,'name1');
INSERT 0 1
postgres=# insert into t2(id,name) values (1,'name1');
INSERT 0 1

查看訂閱端,只有已新建訂閱的表數(shù)據(jù)同步
postgres=# select * from t1;
 id | name
----+-------
  1 | name1
(1 row)

postgres=# select * from t2;
 id | name
----+------
(0 rows)

為新表添加同步

發(fā)布端,將t2加入到發(fā)布
postgres=# alter publication pub_test add table t2;
ALTER PUBLICATION

查看發(fā)布表
postgres=# select * from pg_publication_tables;
 pubname  | schemaname | tablename
----------+------------+-----------
 pub_test | public     | t1
 pub_test | public     | t2
(2 rows)

訂閱端,刷新訂閱配置
postgres=# alter subscription sub_test refresh publication;
ALTER SUBSCRIPTION

發(fā)布端,分別向t1 t2插入數(shù)據(jù)
postgres=# insert into t1(id,name) values (2,'name2');
INSERT 0 1
postgres=# insert into t2(id,name) values (2,'name2');
INSERT 0 1

訂閱端,查看t1 t2的數(shù)據(jù)
postgres=# select * from t1;
 id | name
----+-------
  1 | name1
  2 | name2
(2 rows)

postgres=# select * from t2;
 id | name
----+-------
  1 | name1
  2 | name2
(2 rows)

復(fù)制標(biāo)識(shí) REPLICA IDENTITY

REPLICA IDENTITY,復(fù)制標(biāo)識(shí),共有4種配置模式,分別為,

  • 默認(rèn)模式(default):
    非系統(tǒng)表采用的默認(rèn)模式,如果有主鍵,則用主鍵列作為身份標(biāo)識(shí),否則用完整模式。
  • 索引模式(index):將某一個(gè)符合條件的索引中的列,用作身份標(biāo)識(shí)。
  • 完整模式(full):將整行記錄中的所有列作為復(fù)制標(biāo)識(shí)(類似于整個(gè)表上每一列共同組成主鍵)。
  • 無(wú)身份模式(nothing):不記錄任何復(fù)制標(biāo)識(shí),這意味著UPDATE|DELETE操作無(wú)法復(fù)制到訂閱者上。

表改復(fù)制標(biāo)識(shí)可以通過(guò)ALTER TABLE進(jìn)行修改。
ALTER TABLE T1 REPLICA IDENTITY { DEFAULT | USING INDEX index_name | FULL | NOTHING};

T1沒(méi)有主建,直接刪除,提示需要設(shè)置 REPLICA IDENTITY
postgres=# delete from t1 where id=1;
ERROR:  cannot delete from table "t1" because it does not have a replica identity and publishes deletes
HINT:  To enable deleting from the table, set REPLICA IDENTITY using ALTER TABLE.

修改為full,刪除成功
postgres=# alter table t1 replica identity full;
ALTER TABLE
postgres=# delete from t1 where id=1;
DELETE 1

到此這篇關(guān)于postgresql 邏輯復(fù)制的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)postgresql 邏輯復(fù)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法

    PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法

    這篇文章主要為大家詳細(xì)介紹了PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • PostgreSQL 用戶名大小寫規(guī)則小結(jié)

    PostgreSQL 用戶名大小寫規(guī)則小結(jié)

    PostgreSQL默認(rèn)不區(qū)分用戶名大小寫,創(chuàng)建和連接時(shí)自動(dòng)轉(zhuǎn)為小寫,使用雙引號(hào)可強(qiáng)制區(qū)分,下面就來(lái)介紹一下PostgreSQL 用戶名大小寫規(guī)則,感興趣的可以了解一下
    2025-06-06
  • postgresql分頁(yè)數(shù)據(jù)重復(fù)問(wèn)題的深入理解

    postgresql分頁(yè)數(shù)據(jù)重復(fù)問(wèn)題的深入理解

    這篇文章主要給大家介紹了關(guān)于postgresql分頁(yè)數(shù)據(jù)重復(fù)問(wèn)題的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用postgresql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 基于Postgresql 事務(wù)的提交與回滾解析

    基于Postgresql 事務(wù)的提交與回滾解析

    這篇文章主要介紹了基于Postgresql 事務(wù)的提交與回滾解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • Postgresql數(shù)據(jù)庫(kù)SQL字段拼接方法

    Postgresql數(shù)據(jù)庫(kù)SQL字段拼接方法

    Postgresql里面內(nèi)置了很多的實(shí)用函數(shù),下面這篇文章主要給大家介紹了關(guān)于Postgresql數(shù)據(jù)庫(kù)SQL字段拼接方法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • PostgreSQL教程(十):性能提升技巧

    PostgreSQL教程(十):性能提升技巧

    這篇文章主要介紹了PostgreSQL教程(十):性能提升技巧,本文講解了使用EXPLAIN、批量數(shù)據(jù)插入、關(guān)閉自動(dòng)提交、使用COPY、 刪除索引、刪除外鍵約束等技巧,需要的朋友可以參考下
    2015-05-05
  • postgresql查詢每個(gè)月的最后一天日期并對(duì)未查到的日期結(jié)果補(bǔ)0(操作示例)

    postgresql查詢每個(gè)月的最后一天日期并對(duì)未查到的日期結(jié)果補(bǔ)0(操作示例)

    這篇文章主要介紹了postgresql查詢每個(gè)月的最后一天日期,并對(duì)未查到的日期結(jié)果補(bǔ)0,pgsql需要使用函數(shù)使用date_trunc()函數(shù)找到指定月第一天,然后對(duì)該日期先加一個(gè)月在減一個(gè)月就能得到你傳給的日期的最后一天日期,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • postgresql 實(shí)現(xiàn)更新序列的起始值

    postgresql 實(shí)現(xiàn)更新序列的起始值

    這篇文章主要介紹了postgresql 實(shí)現(xiàn)更新序列的起始值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Docker修改Postgresql密碼的方法詳解

    Docker修改Postgresql密碼的方法詳解

    在Docker環(huán)境中,對(duì)已運(yùn)行的PostgreSQL數(shù)據(jù)庫(kù)實(shí)例進(jìn)行密碼更改是一項(xiàng)常見(jiàn)的維護(hù)操作,下面將詳述如何通過(guò)一系列命令行操作來(lái)實(shí)現(xiàn)這一目標(biāo),需要的朋友可以參考下
    2024-07-07
  • 如何獲取PostgreSQL數(shù)據(jù)庫(kù)中的JSON值

    如何獲取PostgreSQL數(shù)據(jù)庫(kù)中的JSON值

    這篇文章主要介紹了如何獲取PostgreSQL數(shù)據(jù)庫(kù)中的JSON值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01

最新評(píng)論