Eureka 由 Netflix 开发,是一种基于REST(Representational State Transfer)的服务,用于定位服务(服务注册与发现),以实现中间层服务的负载均衡和故障转移,此服务被称为 Eureka Server。同时,它还附带了基于 Java 的客户端组件:Eureka Client,它使得客户端与 Eureka Server 的交互变得更加的容易。 以下就是一个简单的服务调用过程:
由服务提供方将服务注册到 Eureka Server
服务消费者通过 Eureka Server 获取服务提供方的真实地址
服务消费者通过真实的地址调用服务
搭建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>eureka</artifactId>
<groupId>com.et</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>eureka-server</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</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-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
<version>${eureka.version}</version>
</dependency>
</dependencies>
</project>
package com.et.eureka;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
节点1配置信息
server:
port: 8761
eureka:
instance:
hostname: node1 # eureka name
prefer-ip-address: false
client:
fetch-registry: false
register-with-eureka: true
# eureka url
service-url:
defaultZone: http://node2:8762/eureka
spring:
application:
name: "eureka-server-ha"
节点2配置信息
server:
port: 8762
eureka:
instance:
hostname: node2 # eureka name
prefer-ip-address: false
client:
fetch-registry: false
register-with-eureka: true
# eureka url
service-url:
defaultZone: http://node1:8761/eureka
spring:
application:
name: "eureka-server-ha"
/etc/hosts
127.0.0.1 node1
127.0.0.1 node2
以上只是一些关键代码,所有代码请参见下面代码仓库
https://github.com/Harries/springcloud-demo
启动node1,node2
访问http://127.0.0.1:8761/
https://docs.spring.io/spring-cloud-netflix/docs/current/reference/html/#service-discovery-eureka-clients
https://nicklee1006.github.io/Spring-Cloud-3-Eureka-Clustering/
http://www.liuhaihua.cn/archives/710895.html