介绍
微服务的注册中心常见有:eureka、dubbo+zookeeper、nacos 、consul、Sentinel等,实际使用中根据需求选择合适的注册中心,文章主要记录下eureka注册中心搭建。
项目结构
父依赖
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<gson.version>2.8.6</gson.version>
<spring.cloud.version>2.2.2.RELEASE</spring.cloud.version>
<spring.boot.version>2.2.5.RELEASE</spring.boot.version>
<test.version>2.0.2.RELEASE</test.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR4</version>
</dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>${gson.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-context</artifactId>
<version>${spring.cloud.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>${spring.boot.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
eureka-server
- 依赖
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
<version>2.2.2.RELEASE</version>
</dependency>
</dependencies>
- 配置文件
server:
port: 7001
spring:
application:
name: spring-cloud-eureka
eureka:
client:
instance:
hostname: org.eureka.7001.com # 主机名,配置hosts模拟多个主机
register-with-eureka: false #是否将自己注册到服务中,默认true
fetch-registry: false # 是否从服务中获取注册信息,
serviceUrl:
defaultZone: http://org.eureka.7001.com:7001/eureka,http://org.eureka.7002.com:7002/eureka
- 启动类
@SpringBootApplication
@EnableEurekaServer
public class EurekaApp7001 {
public static void main(String[] args) {
SpringApplication.run(EurekaApp7001.class, args);
}
}
eureka-7002 类似,修改端口,启动后如下