Eureka注册中心高可用集群配置
Eureka高可用集群配置
当注册中心扛不住高并发的时候,这时候 要用集群来扛;
我们再新建两个module microservice-eureka-server-2002 microservice-eureka-server-2003
第一步:
pom.xml 把依赖加下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
< dependencies > < dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-starter-eureka-server</ artifactId > </ dependency > <!-- 修改后立即生效,热部署 --> < dependency > < groupId >org.springframework</ groupId > < artifactId >springloaded</ artifactId > </ dependency > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-devtools</ artifactId > </ dependency > </ dependencies > |
第二步:
2002 2003的主启动类EurekaServerApplication_2002,EurekaServerApplication_2003复制修改下;
第三步:
前面单机的时候 eureka注册中心实例名称 是localhost,现在是集群,不能三个实例都是localhost,这里复杂的办法是搞三个虚拟机,麻烦,这里有简单办法,直接配置本机hosts,来实现本机域名映射;
找到 C:\Windows\System32\drivers\etc 打开hosts,加配置
127.0.0.1 eureka2001.java1234.com
127.0.0.1 eureka2002.java1234.com
127.0.0.1 eureka2003.java1234.com
第四步:
修改三个项目的application.yml文件,主要是修改 hostname和defaultZone,
2001修改:
server:
port: 2001
context-path: /
eureka:
instance:
# 单机 hostname: localhost #eureka注册中心实例名称
hostname: eureka2001.java1234.com # 集群
client:
register-with-eureka: false #false 由于该应用为注册中心,所以设置为false,代表不向注册中心注册自己。
fetch-registry: false #false 由于注册中心的职责就是维护服务实例,它并不需要去检索服务,所以也设置为false
service-url:
defaultZone: http://eureka2002.java1234.com:2002/eureka/,http://eureka2003.java1234.com:2003/eureka/ # 集群
#单机defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #设置与Eureka注册中心交互的地址,查询服务和注册服务用到
2002修改:
server:
port: 2002
context-path: /
eureka:
instance:
# 单机 hostname: localhost #eureka注册中心实例名称
hostname: eureka2002.java1234.com # 集群
client:
register-with-eureka: false #false 由于该应用为注册中心,所以设置为false,代表不向注册中心注册自己。
fetch-registry: false #false 由于注册中心的职责就是维护服务实例,它并不需要去检索服务,所以也设置为false
service-url:
defaultZone: http://eureka2001.java1234.com:2001/eureka/,http://eureka2003.java1234.com:2003/eureka/ # 集群
#单机defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #设置与Eureka注册中心交互的地址,查询服务和注册服务用到
2003修改:
server:
port: 2003
context-path: /
eureka:
instance:
# 单机 hostname: localhost #eureka注册中心实例名称
hostname: eureka2003.java1234.com # 集群
client:
register-with-eureka: false #false 由于该应用为注册中心,所以设置为false,代表不向注册中心注册自己。
fetch-registry: false #false 由于注册中心的职责就是维护服务实例,它并不需要去检索服务,所以也设置为false
service-url:
defaultZone: http://eureka2001.java1234.com:2001/eureka/,http://eureka2002.java1234.com:2002/eureka/ # 集群
#单机defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #设置与Eureka注册中心交互的地址,查询服务和注册服务用到
第五步:修改服务提供者项目的application.yml,主要修改eureka.client.service-url.defaultZone
server:
port: 1001
context-path: /
# 数据源配置
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/db_springcloud2
username: root
password: 123456
jpa:
hibernate:
ddl-auto: update
show-sql: true
eureka:
instance:
hostname: localhost #eureka客户端主机实例名称
appname: microservice-student #客户端服务名
instance-id: microservice-student:1001 #客户端实例名称
prefer-ip-address: true #显示IP
client:
service-url:
# 单机 defaultZone: http://localhost:2001/eureka #把服务注册到eureka注册中心
defaultZone: http://eureka2001.java1234.com:2001/eureka/,http://eureka2002.java1234.com:2002/eureka/,http://eureka2003.java1234.com:2003/eureka/ # 集群
info:
groupId: $project.groupId$
artifactId: $project.artifactId$
version: $project.version$
负责人: 张三
联系电话: 110
最后我们测试下:
启动三个注册中心,以及服务提供者项目;
然后浏览器地址栏输入:http://eureka2001.java1234.com:2001/
这里说明,集群创建OK; 红色的那块 ,后面会讲到,是eureka的自我保护。
假如访问 http://eureka2002.java1234.com:2002/ http://eureka2003.java1234.com:2003/
都是一个效果;
这里本质是三个服务注册中心都有我们服务提供者的信息,等后面讲到服务发现和服务调用,我们通过一些策略(默认轮询),会去找对应的服务注册中心;通过集群,能减轻每个服务注册中心的压力;
最新文章
- 写了好多次SSH现在对于框架还是有一定的基础了,但是对于框架下我们该如何进行操作呢???
- IOS高级编程之三:IOS 多线程编程
- 查看Msi文件内容
- atitit.自适应设计悬浮图片的大小and 位置
- RequireJS初探
- PXE批量部署linux操作系统
- Kadj Squares - POJ 3347
- WCF引用方式
- pdf文件之itextpdf操作实例
- python 操作mysql数据库demo
- 1.2 NCE22 By heart
- JMeter 通过JSON Extractor 插件来提取响应结果
- go语言中的strings常用函数和格式化输出
- 695. Max Area of Island
- 轻量级IOC框架:Ninject (上)
- maven 配置jdk版本编译
- Letter Combinations of a Phone Number - LeetCode
- python numpy 学习
- IDEA + SSH OA 第一天(IDEA 文件夹类型了解)
- JavaScript - this详解 (二)
热门文章
- Oracle:存储过程的使用
- oracle-按年、月、周、日、时、分 分组查询统计数据,无数据补零(connect by)
- EntityFramework Core表名原理解析,让我来,揭开你神秘的面纱
- 网络流 - 最大流构图入门 bzoj 1305
- java架构之路(多线程)JUC并发编程之Semaphore信号量、CountDownLatch、CyclicBarrier栅栏、Executors线程池
- java 常用锁
- 2019 牛客国庆集训day1 2019 点分治
- 为什么Mozilla Thunderbird无法登陆腾讯企业邮?
- 异常java.lang.NoSuchMethodError: org.springframework.core.GenericTypeResolver.resolveTypeArguments(Ljava/lang/Class;Ljava/lang/Class;)[Ljava/lang/Class;
- (树形DP入门题)Anniversary party(没有上司的舞会) HDU - 1520