官网地址: https://www.consul.io/intro
中文地址: https://www.springcloud.cc/spring-cloud-consul.html
consul也是服务注册中心的一个实现,是由go语言写的。
Consul是一套开源的分布式服务发现和配置管理系统。提供了微服务系统中的服务治理,配置中心,控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网络。
1.服务发现:提供HTTP和DNS两种发现方式
2.健康监测:支持多种方式,HTTP、TCP、Docker、Shell脚本定制化
3.KV存储:Key、Value的存储方式
4.多数据中心:Consul支持多数据中心
5.可视化Web界面
安装并运行:
下载地址:https://www.consul.io/downloads.html
或者链接:https://pan.baidu.com/s/1cuBGN_YXFm0IsJNSrNqTBA
提取码:w6kb
步骤:
1.打开下载的压缩包,只有一个exe文件,实际上是不用安装的,在exe文件所在目录打开dos窗口使用即可(cmd)
2.consul --verion查看版本
3.使用开发模式启动:consul agent -dev
4.访问8500端口,即可访问首页:http://localhost:8500/
分别创建服务提供者和消费者(springboot项目):
服务提供者:consul-provider-payment
<!--springcloud consul server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
server:
port: 8006
spring:
application:
name: cconsul-provider-payment
cloud:
consul:
host: localhost //consul的ip地址
port: 8500
discovery: # 指定注册对外暴露的服务名称
service-name: ${spring.application.name}
public class PaymentController {
@Value("${server.port}")
private String serverPort;
@RequestMapping("/payment/consul")
public String paymentConsul(){
return "springcloud with consul :" + serverPort + "\t" + UUID.randomUUID().toString();
}
}
@SpringBootApplication
@EnableDiscoveryClient
public class PaymentMain8006 {
public static void main(String[] args){
SpringApplication.run(PaymentMain8006.class,args);
}
}
服务消费者:consul-customer-payment
<!--springcloud consul server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
server:
port: 80
spring:
application:
name: consul-customer-payment
cloud:
consul:
host: localhost
port: 8500
discovery: # 指定注册对外暴露的服务名称
service-name: ${spring.application.name}
@RestController
@Slf4j
public class OrderController {
public static final String INVOKE_URL="http://consul-provider-payment";
@Resource
private RestTemplate restTemplate;
@RequestMapping("/customer/payment/consul")
public String paymentInfo(){
String result = restTemplate.getForObject(INVOKE_URL + "/payment/consul",String.class);
return result;
}
}
@SpringBootApplication
@EnableDiscoveryClient
public class OrderConsulMain80 {
public static void main(String[] args){
SpringApplication.run(OrderConsulMain80.class,args);
}
}
confg文件ApplicationContextConfig
@Configuration
public class ApplicationContextConfig {
/*
RestTemplate提供了多种便捷访问远程http服务的方法,
是一种简单便捷的访问restful服务模板类,是spring提供的用于rest服务的客户端模板工具集
*/
@Bean
@LoadBalanced //负载均衡
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
}
分别启动服务提供者和消费者:
consul-provider-payment
consul-customer-payment
查看consul图形界面,查看健康状态
访问路径:http://localhost/customer/payment/consul
结果如下: