Consul简介
Consul(Go语言编写)是一套开源的分布式服务发现和配置管理系统
提供了微服务系统中的服务治理、配置中心、控制总线等功能,这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之consul提供了一种完整的服务网格解决方案
主要功能:服务注册与发现、健康检查、键值对存储、安全加固,多数据中心;
安装并运行Consul
官方下载后运行exe文件
cmd:consul agent-dev即可查看版本信息,查看是否安装成功
访问localhost:8500即可进入consul前端图像化界面
服务提供者
新建Module支付服务provider8006
- 修改pom文件(引入Consul依赖)
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-cloud-starter-web</artifactId>
</dependency>
-
修改yaml文件
-
添加主启动类(注意这里需要@EnableDiscoveryClient注解)
-
创建一个访问后返回ServerPort的Controller;
-
启动8006服务,访问后返回ServerPort
服务消费者
新建Module消费服务80
maven依赖,主启动类yml文件和之前一样,Consul端口填上面的8500(即yml文件只改项目端口)
然后编写RestConfig配置文件,对RestConfig进行配置,和之前一样;
编写Controller文件,使用RestTemplate访问服务者的地址;
最后进行测试
三个注册中心异同点
都可以集成SpringCloud
组件名 | 语言 | CAP(主要保证) | 服务健康检查 | 对外暴露接口 |
---|---|---|---|---|
Eureka | Java | AP(高可用) | 可配支持 | HTTP |
Consul | Go | CP(数据一致) | 支持 | HTTP/DNS |
Zookeeper | Java | CP | 支持 | 客户端 |
CAP理论:
C:Consistency(强一致性)
A:Availability(可用性)
P:Partition tolerance(分区容错性)
CAP理论关注的力度是数据
Eureka注重高可用性(AP):服务一会宕机不会立马删除,会留着
Consul/zookeeper注重数据一致性(CP):当网络分区之后,为了保证一致性,就必须拒接请求,否则无法保证一致性