Spring Cloud Eureka使用Netflix Eureka来实现服务注册与发现,它既包含了服务端组件也包含了客户端组件。
以下为建立一个Eureka的详细步骤,为方便后续的项目添加环境统一,用Maven的model方式处理。
1 单例模式
1.1 代码目录:
如上图所示,两个pom文件,POM1是Maven大框架的环境,POM2是Eureka使用到的独立环境。
1.2 Maven环境
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.lyc.spring.cloud</groupId>
<artifactId>springCloudTwo</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<name>spring-cloud-two</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.8.RELEASE</version>
<relativePath/>
</parent>
<properties>
<project.build.sourceEnncoding>UTF-8</project.build.sourceEnncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<!--dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency-->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<modules>
<module>eureka_server</module>
</modules>
</project>
1.3 Eureka依赖包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>springCloudTwo</artifactId>
<groupId>com.lyc.spring.cloud</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>eureka_server</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka-server</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
</dependencies>
</project>
1.4 properties文件
application.properties:
server.port=1101
spring.application.name=server1
eureka.instance.hostname=localhost
eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:1101/eureka
1.5 启动类
package com.lyc.spring;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@EnableEurekaServer
@SpringBootApplication
public class Application {
public static void main(String[] args) {
new SpringApplicationBuilder(Application.class).web(true).run(args);
}
}
1.6 启动
可以直接用IDE去Run启动类,
启动完结后,访问浏览器:http://localhost:1101得到如下界面:
至此,eureka的单例完结。
2 高可用模式
高可用模式在单例模式之上做一些相应的改动即可。
2.1 代码目录:
如上图所示,两个pom文件,POM1是Maven大框架的环境,POM2是Eureka使用到的独立环境。与单例模式不同的是添加了两个properties文件
2.2 Maven环境
同单例模式
2.3 Eureka依赖包
同单例模式
2.4 properties文件
application.properties:
spring.profiles.active=host1
application-host1.properties:
server.port=1101
spring.application.name=server1
# 高可用配置部分
eureka.instance.server.port1=1101
eureka.instance.server.port2=1102
eureka.instance.hostname=localhost
eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${eureka.instance.server.port2}/eureka
application-host2.properties:
server.port=1102
spring.application.name=server2
# 高可用配置部分
eureka.instance.server.port1=1101
eureka.instance.server.port2=1102
eureka.instance.hostname=localhost
eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${eureka.instance.server.port1}/eureka
2.5 启动类
同单例模式
2.6 启动
启动的方式我们换一种,因为springBoot自带有tomcat容器,所以我们可以直接用java -jar命令行来启动
java -jar eureka_server-1.0-SNAPSHOT.jar --spring.profiles.active=host1
java -jar eureka_server-1.0-SNAPSHOT.jar --spring.profiles.active=host2
我们启动两个实例,看他们是否能够自动发现,如下所示:
待两个实例都启动完结后,访问浏览器:http://localhost:1101或者http://localhost:1102得到如下界面:
至此,eureka的高可用实例完结。