STEP 1 : Eureka 微服务的注册
作为spring-cloud中最重要最核心的组件,spring-cloud学习的第一步当然是学习使用Eureka.
首先让我们先了解一下Eureka的背景.
Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的服务注册和发现。也是spring-cloud体系中最重要最核心的组件之一。
既然是提供服务注册与,那当然需要有server(服务注册中心) 、client(服务提供方) 以及** consumer(服务消费者)**,由于篇幅有限,接下来,我们只针对对server和client进行学习.
服务注册中心 (server)
在spring-cloud的代码中已经主动帮我们实现了服务注册中心,这样让开发人员只需要非常简单的几个步骤就可以实现服务注册中心的搭建.
1.初始化
方法一 : 使用spring initializr进行快速初始化
spring initializr 能帮助开发人员快速搭建项目的文件结构以及各种依赖.
- 填写组织名称和项目名称
- 搜索
Eureka Server
,并选中 - Generate Project (即下载项目包)
- 将项目包解压并导入到IDE中
方法二 : 使用IDE自带的工具进行初始化
此处使用IntelliJ IDEA作为IDE进行演示
- 新建spring initializr项目
- 填写组织名称和项目名称
- 选中 Cloud Discovery下的Eureka Server
在使用spring initializr作为项目初始化工具时,直接选择Eureka Server将默认引入spring-cloud支持而不需要手动引入spring-cloud-starter
如果未使用spring initializr工具,则需要手动引入spring-cloud依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter</artifactId>
</dependency>
2.配置
在启动代码中添加 @EnableEurekaServer
注解:
@SpringBootApplication
@EnableEurekaServer
public class SpringCloudEurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudEurekaServerApplication.class, args);
}
}
在默认设置下,该服务注册中心也会将自己作为客户端来尝试注册它自己,所以我们需要禁用它的客户端注册行为,在application.properties
添加以下配置:
spring.application.name=spring-cloud-eureka-server
server.port=9999
eureka.client.register-with-eureka=false //表示是否将自己注册到Eureka Server,默认为true
eureka.client.fetch-registry=false //表示是否从Eureka Server获取注册信息,默认为true。
eureka.client.serviceUrl.defaultZone=http://127.0.0.1:${server.port}/eureka/
//设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。
3.运行
配置完成后,运行spring-cloud-eureka-server工程,访问 http://127.0.0.1:9999/
,就可以看见以下页面,但是并没有任何服务.
服务提供方 (client)
1.初始化
默认情况下,使用和注册中心一样的初始化过程,此处不再重复表示
2.配置
在启动代码中添加 @EnableEurekaClient
注解:
@SpringBootApplication
@EnableEurekaClient
public class SpringCloudEurekaClientApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudEurekaClientApplication.class, args);
}
}
然后修改一下application.properties
:
spring.application.name=spring-cloud-eureka-client
server.port=1001
eureka.client.service-url.defaultZone=http://127.0.0.1:9999/eureka/
此时就已经可以成功注册这个服务端到注册中心了,但是这个服务端还没有提供任何服务,所以,现在需要添加一个服务
import com.netflix.discovery.EurekaClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.ArrayList;
import java.util.List;
@RestController
public class HelloWorldController {
@Autowired
@Qualifier("eurekaClient")
private EurekaClient client;
@RequestMapping("/say")
public String say(){
List<String> registeredApps = new ArrayList<>();
client.getApplications().getRegisteredApplications().forEach(item -> registeredApps.add(item.getName()));
return registeredApps.toString();
}
}
3.运行
配置完成后,运行spring-cloud-eureka-client工程,访问 http://127.0.0.1:9999/
,可以在注册中心的已注册服务列表中发现我们绑定的微服务.
然后访问http://127.0.0.1:1001/say
就可以看见输出的结果了
结束
本文部分文本来源于互联网
感谢以下文章提供的灵感和帮助