• 基于nginx的TCP Proxy实现数据库读写分离


    nginx非常早就支持tcp proxy。可是一直不知道其使用,近期在nginx blog上看见了。一些实践者将其运用到数据库訪问的负载均衡以及实现读写分离,来提高数据库的吞吐量,这里我不会讲详细的搭建实现。仅仅是最一些理论上的设计猜想。

    直接上图
    这里写图片描写叙述

    db集群。分为读db和写db。写db向读db同步数据。

    读db仅仅能读,写db仅仅能写。图中读写各一个,仅仅是一个样例,实际须要依据业务来配置读写server比例。

    nginx tcp proxy实现读写分离。提供仅仅读的port和仅仅写的port。

    db connection pool维护两个数据库连接池,一个读一个写,可是对于使用db connection pool的service来说。他们能够直接读写。

    db connection pool须要实现读写操作分离。

    这个系统的一些瓶颈:
    db connection pool须要维护的tcp 连接过多。

    db connection pool与nginx tcp proxy的连接限制。

    数据同步不及时。导致数据一致,比方我一写就读,还没同步。

  • 相关阅读:
    python面向对象__call__
    python的上下文管理协议
    python析构方法__del__
    next和iter可迭代协议
    __slots__ 用法
    定制自己的数据类型
    内置的Attr系列
    反射和自省
    isinstance和issubclass
    BLE 学习
  • 原文地址:https://www.cnblogs.com/jhcelue/p/7074214.html
Copyright © 2020-2023  润新知