zoukankan      html  css  js  c++  java
  • lcn 分布式事务协调者集群原理

    lcn集群原理图:

    1.实现原理:

    1.1 LCN获取tm协调者注册地址

       1. LCN客户端项目启动的时候,首先会注册到事务协调者中去,然后读取配置文件tm事务协调者的注册地址。

       2. 向该事务协调者注册地址发送一个请求,获取对应的lcn底层协议ip和端口号(底层是netty协议通讯)。

       3. 会向该lcn底层协议ip和端口号建立长连接 ,保持会话信息。

    lcn 协调者访问地址,及页面如下图所示。

    客户端配置文件

    tm:
      manager:
        url: http://127.0.0.1:8899/tx/manager/

    2. 基于Nginx 搭建事务协调者集群

       这里所指的端口号指的是事务协调者中配置的 tm.socket.port=9999 的端口号,netty 协议端口号和ip地址。

       1.首先通过nginx配置多个tm协调者负载均衡配置,然后 LCN客户端启动项目的时候访问nginx负载均衡地址获取lcn协议通讯IP地址和端口号,并且对该连接保持长连接。

       2.因为LCN客户端与TM协调者保持的是长连接,当tm协调者宕机之后,LCN会客户端会立即重新进入到获取负载均衡地址lcn协议通讯IP地址和端口号。

       3.如果lcn客户端与事务协调者保持的长连接断开后,那么lcn客户端会在通过Nginx 负载均衡实现故障转移轮询到下一台事务协调者服务器获取对应的lcn底层的ip和端口号,并且建立长连接。

    原理图如下:

    nginx 配置:

    ### 上游服务器 集群  默认轮询

    upstream backserver{

       server 127.0.0.1:8898;

       server 127.0.0.1:8899;

    }

    ### server{

         #### 监听端口号

         listen       80;  

        ####  监听域名地址

        server_name   lcn.test.com

         location / {

             ### 指定上游服务器负载均衡器

            proxy_pass  http://backserver;

            ### nginx 与上游服务器(真是访问的服务器)的超时时间  后端服务器的连接的超时时间_发起握手等候响应超时时间

           proxy_connect_timeout   5s;

           ### nginx 发送给上游服务器(真是访问的服务器)的超时时间

          proxy_send_timeout 5s;

          ### nginx 接受上游服务器(真实访问的服务器)超时时间

         proxy_read_timeout 5s;

         index index.html index.htm;

       }  

    }

    项目源码地址:https://gitee.com/MingTian-NiHao/springboot-lcn 、https://gitee.com/MingTian-NiHao/tx-lcn

  • 相关阅读:
    无法访问局域网其他计算机
    部署好网站,同局域网中电脑无法访问的问题的解决方案
    python——模块
    python字符串实战
    python——迭代器和生成器
    python——面向对象基础
    python——文件操作
    python——面向对象相关
    python——面向对象进阶
    设计模式——单例模式
  • 原文地址:https://www.cnblogs.com/ming-blogs/p/10705270.html
Copyright © 2011-2022 走看看