背景
首先说明下,是在springcloud整合seata时出现的问题,即nacos+seata。
问题描述
在腾讯云上启动seata-server,本地RM注册时总是失败,失败如下。
![](https://img-blog.csdnimg.cn/20210202201657798.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
这个问题很简单,因为涉及ip未截取有关ip的日志,就是因为连接内网ip没连上,问题是简单,但是为什么会出现这个问题呢,或者说怎么解决呢?
分析
要说这个问题得先谈谈SeataAutoConfiguration这个自动配置对象,在初始化SeataDataSourceBeanPostProcessor这个对象时会去注册RM,具体注册过程就不细说了,在DataSourceProxy初始化时会去注册资源。
![](https://img-blog.csdnimg.cn/20210202203319221.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
最终会通过netty客户端去向TC注册。
再继续就是如何通过tx-service-group去获取seata-server的集群实例列表,拿到ip去通信了。那这里清楚了是因为TC向nacos注册时以内网ip向nacos注册了。看看nacos控制台确实如此。那为什么会以内网ip进行注册呢?看看server启动逻辑。
![](https://img-blog.csdnimg.cn/20210203084532616.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20210203084734505.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
原来时server的netty启动时会去注册中心注册,而ip端口就来自xid,那就直接到NetUtil中去寻找答案吧。
![](https://img-blog.csdnimg.cn/20210203085247423.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
到这里再继续就是jdk与jvm的部分了,以后把这部分具体谈谈,这里我们就说到这,从InetAddress获取本机ip会获得内网ip,也就清楚了为什么没有公网ip注册。那如何公网ip注册呢,上面已经有图说明了,当ParameterParser中有ip的时候就从它里边取,也就是要加启动server时要加-h参数,如 sh seata-server.sh -h x.x.x.x。