微服务框架中最为重要的就是注册中心,如果只是单注册中心,一旦出现问题,容易导致整个微服务环境不可用,所以建议注册中心集群。
目前SpringCloud框架中使用Eureka作为注册中心,本文简单介绍一下Eureka的集群配置,主要的思路就是相互注册,形成一组相互注册的注册中心,达到高可用的效果。
一般来说集群配置至少需要2台以上的服务器,这里是采用本机测试,道理是一样的。
org.springframework.boot
spring-boot-starter-parent
2.0.3.RELEASE
org.springframework.cloud
spring-cloud-dependencies
Finchley.RELEASE
pom
import
org.springframework.cloud
spring-cloud-starter-netflix-eureka-server
spring-milestones
Spring Milestones
https://repo.spring.io/milestone
false
第一个注册中心配置
# 服务端口号
server:
port: 8100
# 服务名称必须一样
spring:
application:
name: app-eureka
eureka:
instance:
# 注册中心ip地址(本机地址)
hostname: 127.0.0.1
client:
service-url:
# 注册地址,注册到9100的注册中心,如果是三台以上,一样可以在这边添加
# 主要是实现相互注册
defaultZone: http://127.0.0.1:9100/eureka/
# 将自己注册给自己的注册中心
register-with-eureka: true
# 检索自己服务信息
fetch-registry: false
第二个注册中心配置
# 服务端口号
server:
port: 9100
# 服务名称必须一样
spring:
application:
name: app-eureka
eureka:
instance:
# 注册中心ip地址(本机地址)
hostname: 127.0.0.1
client:
service-url:
# 注册地址,注册到8100的注册中心,如果是三台以上,一样可以在这边添加
# 主要是实现相互注册
defaultZone: http://127.0.0.1:8100/eureka/
# 将自己注册给自己的注册中心
register-with-eureka: true
# 检索自己服务信息
fetch-registry: false
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer //开启EurekaServer服务 开启注册中心
public class AppEureka {
public static void main(String[] args) {
SpringApplication.run(AppEureka.class, args);
}
}
# 订单服务的端口号
server:
port: 8001
# 服务别名 -- 服务注册到注册中心名称
spring:
application:
name: app-order
eureka:
client:
service-url:
# 当前订单服务注册到eureka服务地址,两个注册中心都注册
defaultZone: http://localhost:8100/eureka,http://localhost:9100/eureka
# 需要将服务注册到eureka
register-with-eureka: true
# 需要检索服务
fetch-registry: true
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
@EnableEurekaClient
public class AppOrder {
public static void main(String[] args) {
SpringApplication.run(AppOrder.class, args);
}
}
以上即是Eureka的集群配置,还是比较简单易懂的。