9. Consul

Consul

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

简介

提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之Consul提供了一种完整的服务网格解决方案。

它具有很多优点。包括:基于raft协议,比较简洁;支持健康检查,同时支持HTTP和DNS协议,支持跨数据中心的WAN集群,提供图形界面跨平台,支持Linux、Mac、Windows。

功能

  • 服务发现:提供HTTP和DNS两种发现方式
  • 健康监测:支持多种协议,HTTP、TCP、Docker、 Shell脚本定制化
  • KV存储:key,Value的存储方式
  • 多数据中心:Consul支持多数据中心
  • 可视化Web界面

Windows下安装Consul

1.下载

https://www.consul.io/downloads.html

2.解压

3.配置环境变量

9. Consul

4.安装

打开cmd,切换到安装目录(重点),执行以下命令,效果如下图:

9. Consul

5.测试

http://localhost:8500

9. Consul

安装成功!

将服务提供者添加到注册中心

1.创建cloud-providerconsul-payment8006模块

2.创建pom

		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-consul-discovery</artifactId>
		</dependency>
		
		<!--剩下的使用通用-->

3.创建yml

server:
  port: 8006

spring:
  application:
    name: consul-provider-payment

  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        # hostname: 127.0.0.1
        service-name: ${spring.application.name}

4.创建启动类

PaymentConsulMain8006直接用模板的

5.创建controller

@RestController
@Slf4j
public class PaymentConsulController{
	@Value("${server.port}")
	public String serverPort;
	
	@RequestMapping("/payment/consul")
	public String paymentInfo(){
		return new String("spring cloud with consul:" + serverPort + "\t" + UUID.randomUUID().toString());	
	}
}

5.测试

9. Consul

将服务消费者添加到注册中心

1.创建cloud-consumerconsul-order80

2.创建pom

同8006

3.修改yml

9. Consul

4.创建启动类

OrderConsulMain80使用模板

5.创建配置类

@Configuration
public class ApplicationContextConfig{
	@Bean
	@LoadBalanced
	public RestTemplate getRestTemplate(){
		return new RestTemplate();
	}
}

6.创建controller

@RestController
@Slf4j
public class OrderConsulController{
	public static final String INVOKE_URL = "http://consul-provider-payment";
	
	@Resource
	private RestTemplate restTemplate;
	
	@GetMapping(value = "/consumer/payment/consul")
	public String getPaymentInfo(){
		return restTemplate.getForObject(INVOKE_URL + "/payment/consul" , String.class);
	}
}

7.测试

9. Consul
9. Consul
9. Consul

上一篇:关于go-micro中使用consul的一些注意细节


下一篇:模拟笔记