架构图:
eureka集群
一、eureka server服务集群
建立多个eureka服务,修改yml文件
server:
port: 7001
eureka:
instance:
hostname: eureka7001.com
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://eureka7002.com:7002/eureka/
注意:hostname不能是localhost了,多个服务实例并存,需要有唯一的名字,且需要进行域名映射配置:
127.0.0.1 eureka7001.com
defaultZone集群服务之间互相发现,写入其他需要集群进来的服务域名。
很简单,配置yml完成即可,启动服务,就能在下面看到其他集群服务了。
二、所有服务集群client+server
确保所有client实例加入依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
配置yml:
配置同一client provider服务名称、暴露供消费者调用:
spring:
application:
name: cloud-payment-service
配置需要注册进去的server域名
eureka:
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/
消费者服务修改:
设置RestTemplate调用策略,负载均衡,默认为轮询
@Configuration
public class ApplicationContextConfig {
@Bean
@LoadBalanced
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
}
修改调用的URL为服务application name,即provider暴露的应用名称
// public static final String PAYMENT_URL = "http://localhost:8001";
public static final String PAYMENT_URL = "http://cloud-payment-service";
三、启动
先启动集群eureka server端,然后启动所有provider集群,最后启动consumer服务