eureka集群方案:
1.通常我们部署的eureka节点多于两个,根据实际需求,只需要将相邻节点进行相互注册(eureka节点形成环状),就达到了高可用性集群,任何一个eureka节点挂掉不会受到影响。
2.可能会有初学者和我一样,一开始的时候没有完全理解eureka集群的原理,直接把每个eureka节点的url写进配置文件,期望所有的eureka节点进行相互注册。实际上,节点间进行信息同步的时候,只会选取配置文件第一个eureka的url,除非发生url错误,才会依次选取有效url进行信息同步。
3.可能有的童鞋有这样的疑问,eureka节点形成环状以后,相隔的多个节点挂掉,eureka节点的数据就会出现不一致的情况。长话短说,要么忍,要么改变方案。
忍其实也是合理的,毕竟挂掉的eureka节点重新启动后会自动同步数据。
改变方案可以把所有的eureka进行相互注册,但把所有的eureka url都写一遍,这个着实有点令人不爽,万一新增节点,所有的节点都需要改一遍!!
所以我们很自然的想到了是否可以通过dns来解决上面的问题?eureka的开发者当然也想到了这种问题,并提供了基于dns的解方案。
一、搭建DNS服务器(unbutun环境)
1.ubuntu需安装bind9软件包来配置dns-server
apt-get install bind9
2.配置dns
2.1添加zone
vim /etc/bind/named.conf.local 加入以下配置,可参考/etc/bind/zones.frc1918中的格式
"eureka.com" { type master; file "/etc/bind/db.eureka.com"; };
2.2创建db.eureka.com文件(需要和2.1添加的file文件同名)
cp db.local db.eureka.com
2.3修改db.eureka.com
添加以下内容
txt.huabei.huabei IN TXT "huabei.eureka.com"
txt.huabei IN TXT "192.168.0.1" "192.168.0.2" "192.168.3"
2.4修改named.conf.options配置文件,这里选用循环给出结果的方式
rrset-order { order cyclic; };
3.修改域名解析配置文件
vim /etc/resolv.conf
加入nameserver 192.168.0.1
注意nameserver顶格写 ip可配置本机ip
4.重启服务
/etc/init.d/bind9 restart
二、eureka集群配置
spring:
application:
name: eureka-server
server:
port: 8081
eureka:
environment: alpha
client:
region: huabei
availability-zones:
huabei: hb10
eureka-server-d-n-s-name: huabei.eureka.com
use-dns-for-fetching-service-urls: true
eureka-server-port: 8081
三、总结
笔者也是首次使用spring-cloud,网上有很多适合入门的使用文档,但在实际项目应用中,我们需要进一步挖掘spring-cloud的特性。后续我继续分享关于eureka的相关知识,比如如何使用region、zone等。