服务注册与发现 -- Eureka
一、简单介绍
Eureka是spring cloud中的一个负责服务注册与发现的组件,是Netflix开发的服务发现框架,本身是一个基于REST的服务。它和 zookeeper、Consul,nacos一样,都是用于服务注册管理的 。这里我们先说下Eureka。一个Eureka中分为eureka server和eureka client。其中eureka server是作为服务的注册与发现中心。eureka client既可以作为服务的生产者,又可以作为服务的消费者。
二、上手
spring cloud是基于spring boot进行的开发,因此我们需要创建一个spring boot项目,同时在里面添加eureka server包。
1. 先搭建父级项目
搭建父级项目的是多次下篇文章继续使用。
父级项目使用maven创建,new --> Project -- >maven ,直接点击NEXT,出现GAV坐标要填写,本次demo使用 com.dzbiao.springcloud
,artifactId 为springcloud-collection
。当然自定义也可。
我们在pom.xml 统一下jar包管理。
<?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.dzbiao.springcloud</groupId>
<artifactId>springcloud-collection</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>eureka-server-8761</module>
</modules>
<!--统一管理jar包版本-->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<mybatis.spring.boot.version>2.1.4</mybatis.spring.boot.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-plugins</artifactId>
</dependency>
<!--spring boot 2.3.9-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.3.9.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--spring cloud Hoxton.SR1-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<addResources>true</addResources>
</configuration>
</plugin>
</plugins>
</build>
</project>
同时删除父级项目的src文件夹,只留下pom.xml即可。
2.eureka-server-8761
新建 eureka-server-8761的maven项目,父级项目为我们刚刚建立的springcloud-collection
,pom.xml如下:
<?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>springcloud-collection</artifactId>
<groupId>com.dzbiao.springcloud</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.dzbiao.springcloud</groupId>
<artifactId>eureka-server-8761</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<!--springboot-starter-web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!--springboot2.x使用 Netflix-eureka-server -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
</project>
然后编辑 application.yml
server:
port: 8761
eureka:
instance:
hostname: localhost
client:
fetch-registry: false
register-with-eureka: false
service-url:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
src/main/java 创建com.dzbiao.EureKaServerApplication 启动类,添加 @EnableEurekaServer 注解。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer // 注册中心添加该注解
public class EureKaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EureKaServerApplication.class,args) ;
}
}
启动该main方法,开启服务注册中心。访问 : http://localhost:8761/ , 可以看到如下页面 :
上图最下面的英文 No instances available
是说没有可用的实例,也就是说我们仅仅开启了一个注册中心,还没有客户端或者服务进行注册。
3. eureka-client 客户端服务
我们就在下面创建两个客户端服务,eureka-client-8762
和 eureka-client-8763
,两个服务一样,只是端口不同。
eureka-client-8762 和eureka-client-8763的pom.xml 都为:
<dependencies>
<!--springboot-starter-web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!-- eureka-server -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
</dependency>
</dependencies>
eureka-client-8762 和eureka-client-8763的application.yml 都为:(注意更改端口)
# 注意更改端口号
server:
port: 8763
spring:
application:
name: service
client:
service-url:
defaultZone: http://localhost:8761/eureka
eureka-client-8762 的启动类 EurekaClientApplication8762
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
@EnableEurekaClient // 客户端注册
public class EurekaClientApplication8762 {
public static void main(String[] args) {
SpringApplication.run(EurekaClientApplication8762.class,args);
}
}
eureka-client-8763 的启动类 EurekaClientApplication8763
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class EurekaClient8763 {
public static void main(String[] args) {
SpringApplication.run(EurekaClient8763.class,args) ;
}
}
两个服务各新建 controller/UserController.java
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class UserController {
@Value("${server.port}")
private String server_port ;
@GetMapping("user")
public String getUser() {
String str = "端口号:" + server_port ;
return str;
}
}
8762和8763分别启动,访问 localhost:8762/user 和localhost:8763/user ,会返回各自的带端口的字符串。同时我们看看注册中心的注册情况。
我们看到我们的服务已经注册成功,由于服务名称相同,所以上面显示service 有两个服务实例,一个8762,一个8763。
至此我们的eureka注册中心和服务注册全部成功。