8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

如何在 RDS 上的逻辑副本上启用读写操作?

Mukesh Sharma 2月前

20 0

我在 AWS RDS Postgresql 上有一个蓝绿部署,它基本上使用了 Postgresql 的逻辑复制。每当在绿色环境中的表 A 上进行插入时,我都希望插入到

我在 AWS RDS Postgresql 上有一个蓝绿部署,它基本上使用 Postgresql 的逻辑复制。每当在绿色环境中的表 A 上进行插入时,我都希望将其插入到绿色环境中的表 A 和 A 分区中。

对于这种情况,我使用了一个触发器,每当触发时就会调用一个函数:

    CREATE OR REPLACE TRIGGER some_trigger
        BEFORE INSERT ON A
        FOR EACH ROW
        EXECUTE function insert_to_B ();

    CREATE OR REPLACE FUNCTION insert_to_B ()
        RETURNS TRIGGER
        LANGUAGE plpgsql
        SET default_transaction_read_only = off
        AS $TRIG$
    BEGIN
        IF TG_OP = 'INSERT' THEN

            INSERT INTO public.B VALUES ( NEW.*);

            RETURN NEW;

        END IF;

    END

    $TRIG$;



问题是,目前 rds 仅允许您在会话级别修改 default_transaction_read_only。

这导致插入失败: 错误:无法在只读事务中执行 INSERT

有办法解决这个问题吗?应用程序可以将此插入包装在可以设置事务读写的事务块中吗?还有其他解决方案吗?

帖子版权声明 1、本帖标题:如何在 RDS 上的逻辑副本上启用读写操作?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Mukesh Sharma在本站《postgresql》版块原创发布, 转载请注明出处!
最新回复 (0)
返回
作者最近主题: