Spring Cloud 系列——Eureka

本贴最后更新于 1888 天前,其中的信息可能已经天翻地覆

  从这篇文章开始我们共同走进 Spring Cloud 的世界,共同了解目前互联网微服务的利器——Spring Cloud 是如何帮助我们更好的构建微服务体系。如果您还没有接触过微服务,或者没有接触过 Spring Cloud,这个系列能帮助你对 Spring Cloud 有一个全面和整体的认识。

  在微服务架构出现前,我们的软件系统都使用单体架构,随着互联网的发展,微服务架构成为了越来越多互联网公司的首选架构体系,由于篇幅有限,本文不详述微服务与单体系统之间的异同。仅以一个简单易懂的类比故事来阐述微服务与单体系统的区别:我们以一个样样精通的厨师类比为一个单体系统,这个厨师需要提供完成一道菜所需要的每一项功能——选材、洗碗、洗菜、切菜、炒菜、洗锅、端菜等等,每次客人点菜,厨师完成了所有工作,然后给客人端上菜,这些功能就好比一个单体系统的功能,样样俱全。微服务架构就好比上面的每个功能都有一个专门负责这些工作的人来做,每个人之间通过特定的方式来交流。这样做的好处是每个人都各自干好自己负责的活,每个人可以独立的去进行培训(升级、修改),不会对其他人造成影响。这个小故事只是大概说明了微服务和单体应用之间的区别,对于初次接触微服务的同学,能有初步的认识。

  从单体系统架构往微服务架构发展,中间自然会有非常多的问题,Spring Cloud 会为我们解决微服务架构中产生的各种问题,下面进入我们的 Spring Cloud 全家桶时间——Eureka。

  Eureka 的主要功能:搭建服务的注册中心,提供服务的注册和服务的发现。下面介绍如何从 0 搭建一个 Eureka Server(后面的搭建都是基于 Spring Boot 2.1.0 和 Spring Cloud 2.0.0——Finchley.RELEASE 版,并使用 intellij idea)。

1.创建一个基础的 Spring Boot 项目

image.png

2.引入 Eureka Server 包,并配置 Spring Cloud 的版本


 <dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
</dependencies>

<!-- dependencyManagement只管理版本,不会实际下载jar包 -->
<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>

3.在 resources 目录下添加配置文件,并如下图添加配置(本文使用 yml 文件)


server:
  port: 2222
eureka:
  client:
    register-with-eureka: false
    fetch-registry: false
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
  instance:
    hostname: localhost

1.server.port:Erueka Server 的端口
2.eureka.client.register-with-eureka:表示是否向注册中心注册自己(注册中心不需要注册自己)
3.eureka.client.fetch-registry:表示是否检索服务(注册中心不需要检索服务,所以设为 false)
4.eureka.client.service-url.defaultZone:服务中心的默认空间(服务注册的时候会用到)

4.启动类中添加注解 @EnableEurekaServer

image.png
启动 Spring boot 应用,访问 http://localhost:2222,能看到以下页面即为配置成功
image.png

现在可以看到中间的 Instances currently registered with Eureka 是 No instances available,表示当前服务中心并没有服务注册,下面我们建立一个简单的 Eureka Client 注册到服务中心当中

1.同样新建一个 Spring Boot 项目,引入 Spring boot 的 web 模块和 eureka-client 模块
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
</dependencies>
2.同样在 resources 目录下的配置文件中,新增配置
spring:
  application:
    name: test-client-service
#eureka注册中心服务器地址
eureka:
  client:
    service-url:
      defaultZone: http://localhost:2222/eureka/
3.启动类中添加注解 @EnableDiscoveryClient

image.png

4.任意添加一个 RestController

/**
 * @author 关注微信公众号:Java学习交流社区
 * (更多技术干货、原创文章、面试资料,群聊吹水一应俱全)
 */

@RestController
public class DemoController {

    @Autowired
    private IpConfiguration ipConfiguration;

    @RequestMapping("/")
    public String test(){
        return ipConfiguration.getPort()+"";
    }

}

IpConfiguration 用于获取当前端口(为了测试负载均衡时获取不同端口,非必须)


@Component
public class IpConfiguration implements ApplicationListener<WebServerInitializedEvent> {
    private int serverPort;

    @Override
    public void onApplicationEvent(WebServerInitializedEvent event) {
        this.serverPort = event.getWebServer().getPort();
    }

    /**
     * @return 获取本微服务端口号
     */
    public int getPort() {
        return this.serverPort;
    }

}

配置完成,运行 client,可以看到以下画面

Instances currently registered with Eureka 中显示有注册的 client 了,状态为 Up

为了验证注册到服务中心的客户端都能被访问,把 client 项目修改一下端口为 8089,8090 分别导出成 jar 包格式,同时运行两个端口的包。

再另外起一个 Eureka Client 项目,端口为 9002,服务名称为 ribbon-service,与上面介绍的 Client 配置一样,不同点在启动类中添加一下代码:

@Bean
@LoadBalanced
RestTemplate restTemplate(){
    return new RestTemplate();
}

这里使用了 Ribbon 这个 Spring Cloud 的工具包,后面的文章会详细讲解 Ribbon,此处可以先使用,理解为提供一个 http 请求的服务,并负载均衡地请求一个服务的多个提供者

添加一个 RestController 用于此服务的访问


@RestController
@RequestMapping("/ribbon")
public class ConsumerController {

    @Autowired
    private TestClientService testClientService;

    @RequestMapping
    public String helloConsumer(){
        return testClientService.testClientService();
    }

}

创建 Service:


@Service
public class TestClientService{

    @Autowired
    private RestTemplate restTemplate;

    public String testClientService(){
        String testClientService = restTemplate.getForEntity("http://TEST-CLIENT-SERVICE/",String.class).getBody();
        return testClientService;
    }

}

启动后看到界面如下:
image.png
可以到这时候有 2 个服务,其中 TEST-CLIENT-SERVICE 有两个提供者,端口分别为 8089 和 8090,此时我们访问 http://localhost:9002/ribbon,可以看到这时候能够负载均衡地访问到 2 个 TEST-CLIENT-SERVICE
image.png

image.png
结束语:本文讲解了 Spring Cloud 中 Eureka 的注册中心的搭建,服务的注册,以及一个简单的负载均衡访问 Eureka Client 的实例,希望能对读者对 Spring Cloud 的应用能有所帮助。

下一篇将会对 Spring Cloud 中的 Ribbon 和 Feign 的配置及应用进行讲解,想要和我学习 Spring Cloud 系列的同学,记得关注我的微信公众号《Java 学习交流社区》



扫码关注微信公众号《Java学习交流社区》,即可获取原创《Java并发编程与高并发解决方案》+《Redis》思维导图
作者:Java学习交流社区
地址:https://www.jvscc.cn/articles/2019/08/22/1566441527094.html
2 操作
figo2young 在 2019-09-04 14:51:10 更新了该帖
figo2young 在 2019-09-04 14:37:33 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...