Spring Cloud构建微服务架构:Consul服务注册与发现

简介

Spring Cloud Consul项目是针对Consul的服务治理实现。Consul是一个分布式高可用的系统,它包含多个组件,但是作为一个整体,在微服务架构中为我们的基础设施提供服务发现和服务配置的工具。它包含了下面几个特性:

  • 服务发现
  • 健康检查
  • Key/Value存储
  • 多数据中心

由于Spring Cloud Consul项目的实现,我们可以轻松的将基于Spring Boot的微服务应用注册到Consul上,并通过此实现微服务架构中的服务治理。

本文示例代码:consul-demo

实现

在上一遍文章中实现的基于Eureka的示例(eureka-client)为基础,我们如何将之前实现的服务提供者注册到Consul上呢?方法非常简单,我们只需要在pom.xml中将eureka的依赖修改为如下依赖:


        UTF-8
        UTF-8
        1.8
        Dalston.SR2
    

    
        
            org.springframework.cloud
            spring-cloud-starter-consul-discovery
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
        
    

接下来再修改一下application.yml,将consul需要的配置信息加入即可,比如:(下面配置是默认值)

spring:
  cloud:
    consul:
      host: localhost
      port: 8500
  application:
    name: consul-client

入口代码

@EnableDiscoveryClient
@SpringBootApplication
public class ConsulApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConsulApplication.class, args);
    }
}

一个服务提供者的实现

@RestController
public class ServiceSupportController {
    @Autowired
    DiscoveryClient discoveryClient;

    @GetMapping("/test")
    public String test() {

        return "hello world";

    }
}

到此为止,基于consul服务治理的服务提供者就完成了。

前文我们已经有提到过服务发现的接口DiscoveryClient是Spring Cloud对服务治理做的一层抽象,所以可以屏蔽Eureka和Consul服务治理的实现细节,我们的程序不需要做任何改变,只需要引入不同的服务治理依赖,并配置相关的配置属性就能轻松的将微服务纳入Spring Cloud的各个服务治理框架中。

下面可以尝试让consul的服务提供者运行起来。这里可能读者会问,不需要创建类似eureka-server的服务端吗?由于Consul自身提供了服务端,所以我们不需要像之前实现Eureka的时候创建服务注册中心,直接通过下载consul的服务端程序就可以使用。

我们可以用下面的命令启动consul的开发模式:

./consul agent -dev
Spring Cloud构建微服务架构:Consul服务注册与发现_第1张图片
启动consul

consul服务端启动完成之后,我们再将之前改造后的consul服务提供者启动起来。consul与eureka一样,都提供了简单的ui界面来查看服务的注册情况:

Spring Cloud构建微服务架构:Consul服务注册与发现_第2张图片
consul服务治理控制台

本文参考了如下文章:

Spring Cloud构建微服务架构:服务注册与发现(Eureka、Consul)【Dalston版】

Consul的安装
Consul安装 linux环境

服务发现 - consul 的介绍、部署和使用

Consul官网

你可能感兴趣的:(Spring Cloud构建微服务架构:Consul服务注册与发现)