七、consul服务注册与发现

七、consul服务注册与发现_第1张图片

1、Consul简介

是什么?

Consul是一套开源的分布式服务发现的配置管理系统,由HashiCorp用go语言开发

提供了微服务系统中的服务治理,配置中心,控制总线等功能。这些功能中的每一个可以根据需要单独使用,也可以一起

使用构建全方位的服务网络,总之Consul提供了一种完整的服务网格解决方案

能干嘛?

七、consul服务注册与发现_第2张图片

去哪下载?

七、consul服务注册与发现_第3张图片

怎么使用 (中文版 需要仔细学的话可以看这里!)

Spring Cloud Consul 中文文档 参考手册 中文版

2、运行并安装 Consul

下载完成后解压:

七、consul服务注册与发现_第4张图片

在consul.exe的目录下 cmd

七、consul服务注册与发现_第5张图片

输入命令 :consul agent -dev (以开发者模式启动consul)

七、consul服务注册与发现_第6张图片

访问 http://localhost:8500

七、consul服务注册与发现_第7张图片

3、服务提供者注册进consul

我这里就标注下依赖和配置文件,不想粘贴了

① pom文件


    
    
        com.atguigu.springcloud
        cloud-api-commons
        ${project.version}
    
    
    
        org.springframework.cloud
        spring-cloud-starter-consul-discovery
    
    
    
        org.springframework.boot
        spring-boot-starter-web
    
    
        org.springframework.boot
        spring-boot-starter-actuator
    
    
    
        org.springframework.boot
        spring-boot-devtools
        runtime
        true
    
    
        org.projectlombok
        lombok
        true
    
    
        org.springframework.boot
        spring-boot-starter-test
        test
    
    
        cn.hutool
        hutool-all
        RELEASE
        test
    
    
        cn.hutool
        hutool-all
        RELEASE
        test
    

②、yml文件

server:
  port: 8006
spring:
  application:
    name: consul-provider-payment
  #consul服务注册中心地址
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        # 本服务向外暴露的服务名
        service-name: ${spring.application.name}

③ 主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class PaymentMain8006 {
    public static void main(String[] args) {
        SpringApplication.run(PaymentMain8006.class,args);
    }
}

④、业务类

@RestController
@Slf4j
public class PaymentController {
    @Value("${server.port}")
    private String serverPort;

    @RequestMapping(value = "/payment/consul")
    public String paymentzk(){
        return "springcloud with consul:"+ serverPort+ " "+ UUID.randomUUID().toString();
    }
}

4、服务消费者注册进consul

① pom文件


    
    
        org.springframework.cloud
        spring-cloud-starter-consul-discovery
    
    
    
        org.springframework.boot
        spring-boot-starter-web
    
    
        org.springframework.boot
        spring-boot-starter-actuator
    
    
    
        org.springframework.boot
        spring-boot-devtools
        runtime
        true
    
    
        org.projectlombok
        lombok
        true
    
    
        org.springframework.boot
        spring-boot-starter-test
        test
    

②、配置文件

server:
  port: 80
spring:
  application:
    name: cloud-consumer-order
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        service-name: ${spring.application.name}

③ 主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class OrderMainConsul80 {
    public static void main(String[] args) {
        SpringApplication.run(OrderMainConsul80.class,args);
    }
}

④、调用consul-payment8006服务

@RestController
@Slf4j
public class OrderConsulController {
    private static final String INVOKE_URL = "http://consul-provider-payment" ;

    @Autowired
    private RestTemplate restTemplate;


    @GetMapping(value = "/consumer/payment/consul")
    public String paymentInfo(){
        String result = restTemplate.getForObject(INVOKE_URL+"/payment/consul", String.class);
        return result;
    }
}

查看:发现服务消费者 和 提供者确实注册进了consul

七、consul服务注册与发现_第8张图片

订单服务消费者远程调用支付提供者的服务成功!

clipboard

5、三个注册中心的异同点

由于是分布式服务,所以p(分区容错性)是必占的,要么ap,要么cp

七、consul服务注册与发现_第9张图片

AP : eureka

CP: zookeeper 、 consul

你可能感兴趣的:(#,Spring,Cloud,consul)