服务注册发现、配置中心集一体的 Spring Cloud Consul
2021-03-17 15:27
标签:接口 增量 操作系统 复杂 cer red 介绍 end keep 前面讲了 Eureka 和 Spring Cloud Config,今天介绍一个全能选手 「Consul」。它是 HashiCorp 公司推出,用于提供服务发现和服务配置的工具。用 go 语言开发,具有很好的可移植性。被 Spring Cloud 纳入其中,Eureka 停止新版本开发,更多的想让开发者使用 Consul 来作为服务注册发现使用。 服务发现 Consul 让服务注册和服务发现(通过 DNS 和 HTTP 接口)更加简单,甚至对于外部服务(例如SaaS)注册也一样。 故障检测 通过健康检查,服务发现可以防止请求被路由到不健康的主机,并且可以使服务容易断开(不再提供服务)。 多数据中心 Consul 不需要复杂的配置即可简便的扩展到多个数据中心,查找其它数据中心的服务或者只请求当前数据中心的服务。 键值存储 灵活的键值存储,提供动态配置、特征标记、协作、leader 选举等功能,通过长轮询实现配置改变的即时通知。 Spring Cloud Consul 将 Consul 进行自动配置和进一步封装。 Spring Cloud Consul 可替代已有的 Spring Cloud Eureka,也就是当做服务注册发现框架使用。并且 Eureka 2.x 版本也已经停止开发,并且 Spring Cloud 官方也建议用 Spring Cloud Consul 来替代,当然如果已经用了 Eureka 在项目中也没有关系,Eureka 已经足够稳定,正常使用没有任何问题。 Spring Cloud Consul 可替代已有的 Spring Cloud Config ,也就是当做配置中心使用。 Spring Cloud Consul 主要用作服务注册发现,并且官方建议替代 Eureka,那么它肯定具有 Eureka 或其他框架不具备的优势,下面看一下对比它和其他服务发现方式做的一下对比(摘自网络): 服务注册相比 Eureka 会稍慢一些。因为 Consul 的 raft 协议要求必须过半数的节点都写入成功才认为注册成功; Consul 提供了一系列的参数,用于在命令行执行。Consul 默认提供了 web UI 界面来查看配置。通过访问 server 的 8500 端口可以访问到 web UI 控制台。 开发过程中,我们可以通过命令 consul agent -dev 来启动开发模式,启动成功后,访问 localhost:8500 可以看到当前 consul 的所有服务。如下图: 更多的在生成环境的部署可自行搜索相关介绍,这里暂时只用 dev 模式启动,用来介绍 Spring Cloud Consul 的使用。 endpoints: management: @RestController } @SpringBootApplication endpoints: management: @SpringBootApplication } @FeignClient(value = "consul-provider") } @RestController } spring: spring: management: spring: server: spring: server: 3、application.yml 配置文件内容 4、定义配置文件实体类,指定 @ConfigurationProperties 注解,指定前缀为 mysql,也就是 key/value 配置文件中的顶层 key。 5、新建一个 RestController 来获取输出 value 内容 6、最后,启动应用,访问 RestController 中的 RESTful 接口即可看到配置文件内容。 与 Spring Cloud Config 相比,Consul 在控制台修改配置后,会立即更新,不用再结合 Spring Cloud Bus 之类的配合了。 服务注册发现、配置中心集一体的 Spring Cloud Consul 标签:接口 增量 操作系统 复杂 cer red 介绍 end keep 原文地址:https://www.cnblogs.com/miss520net/p/13970659.html
Consul 提供的功能包括如下几个:
功能点
euerka
Consul
zookeeper
etcd
服务健康检查
可配支持
服务状态,内存,硬盘等
(弱)长连接,keepalive
连接心跳
多数据中心
—
支持
—
—
kv 存储服务
—
支持
支持
支持
一致性
—
raft
paxos
raft
cap
ap(高可用、分区容错)
ca(数据一致、高可用)
cp
cp
使用接口(多语言能力)
http(sidecar)
支持 http 和 dns
客户端
http/grpc
watch 支持
支持 long polling/大部分增量
全量/支持long polling
支持
支持 long polling
自身监控
metrics
metrics
—
metrics
安全
—
acl /https
acl
https 支持(弱)
spring cloud 集成
已支持
已支持
已支持
已支持
Leader挂掉时,重新选举期间整个 consul 不可用,以此保证了强一致性但牺牲了可用性。Consul 的安装和启动
与 Eureka 不同,Consul 需要独立安装,可以到官网(https://www.consul.io/downloads.html)下载。具体操作系统的安装方式不同,可参考官网。
实现服务提供者
1、引用 spring-cloud-consul
```
health:
sensitive: false
restart:
enabled: true
shutdown:
enabled: true
security:
enabled: false4、增加一个 RestController ,写两个测试服务方法
@Slf4j
public class HelloController {@Autowired
private DiscoveryClient discoveryClient;
@GetMapping(value = "test")
public String test(){
List
5、Spring boot 启动类
@EnableDiscoveryClient
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}@EnableDiscoveryClient 注解标示这是一个 client 端。
启动这个服务提供者,打开 http://localhost:8500 可以看到这个服务
实现服务消费者
1、引用相关 maven 包,除了引用与上面服务提供者相同的包外,还引用了 openFeign
health:
sensitive: false
restart:
enabled: true
shutdown:
enabled: true
security:
enabled: false4、项目启动类
@EnableDiscoveryClient
@EnableFeignClients
public class Application {@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
使用 @EnableDiscoveryClient 注解表示作为服务 client 端,@EnableFeignClients 启用 openFeign 。
5、新建一个 openFeign 服务接口
public interface IHelloService {@RequestMapping(value = "/hello")
String hello();
@RequestMapping(value = "nice")
String nice();
对应服务提供者中提供的两个 RESTful 接口地址
6、实现一个 RestController 来访问服务提供者开放出来的服务
public class ConsumerController {@Autowired
private LoadBalancerClient loadBalancer;
@Autowired
private DiscoveryClient discoveryClient;
@Autowired
private RestTemplate restTemplate;
@Autowired
private IHelloService helloService;
private final static String SERVICE_NAME = "consul-provider";
/**
* 使用普通的 RestTemplate 方法访问服务
*
* @return
*/
@GetMapping(value = "test")
public Object test() {
String result = restTemplate.getForObject("http://"+SERVICE_NAME + "/test", String.class);
System.out.println(result);
return result;
}
/**
* 使用 openFeign 方式访问服务
*
* @return
*/
@GetMapping(value = "feign")
public Object feign() {
String s = helloService.nice();
return s;
}
/**
* 获取所有服务实例
*
* @return
*/
@GetMapping(value = "/services")
public Object services() {
return discoveryClient.getInstances(SERVICE_NAME);
}
/**
* 从所有服务中选择一个服务(轮询)
*/
@GetMapping(value = "/choose")
public Object choose() {
return loadBalancer.choose(SERVICE_NAME).getUri().toString();
}
启动消费者程序,然后访问对应的 RESTful 接口,可以得到对应的结果。
实现高可用服务提供者
线上的微服务最好不要是单点形式,接下来通过配置来启动两个服务提供者,只要保证 service-name 相同,就表示这是同一个服务。
1、 bootstrap.yml 配置不变
cloud:
consul:
discovery:
service-name: consul-provider
host: localhost
port: 85002、application.yml 修改为如下配置
profiles:
active: consul-provider1
endpoints:
health:
sensitive: false
restart:
enabled: true
shutdown:
enabled: true
security:
enabled: false
profiles: consul-provider1
application:
name: consul-provider1
port: 5000
profiles: consul-provider2
application:
name: consul-provider2
port: 50023、之后启动的时候加上 vm 参数。分别加上参数:
-Dspring.profiles.active=consul-provider1
-Dspring.profiles.active=consul-provider2
分别在 5000 端口和 5002 端口启动服务提供者 consul-provider
4、最后仍然访问消费者的 RESTful 接口地址,可以在服务提供者后台看到每次请求调用的服务实例。
用作配置中心
我们知道,Spring Cloud Config 提供了配置中心的功能,但是需要配合 git、svn 或外部存储(例如各种数据库),那么既然使用了 Consul ,就可以使用 Consul 提供的配置中心功能,并且不需要额外的 git 、svn、数据库等配合使用。
接下来,简单介绍一下 Spring Cloud Consul 如何用作配置中心。Consul 支持 yaml 和 properties 格式的配置文件内容,本例中以 yaml 格式为例。
1、引用相关的 maven 包
spring:
application:
name: consul-config
server:
port: 5008
endpoints:
health:
sensitive: false
restart:
enabled: true
shutdown:
enabled: true
management:
security:
enabled: false
@Component
@ConfigurationProperties(prefix = "mysql")
public class MySqlComplexConfig {
public static class UserInfo{
private String username;
private String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "UserInfo{" +
"username=‘" + username + ‘\‘‘ +
", password=‘" + password + ‘\‘‘ +
‘}‘;
}
}
private String host;
private UserInfo user;
public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public UserInfo getUser() {
return user;
}
public void setUser(UserInfo user) {
this.user = user;
}
}
@RestController
@Slf4j
public class ConfigController {
@Autowired
private MySqlConfig mySqlConfig;
@Autowired
private MySqlComplexConfig mySqlComplexConfig;
@GetMapping(value = "mysqlhost")
public String getMysqlHost(){
return mySqlConfig.getHost();
}
@GetMapping(value = "mysqluser")
public String getMysqlUser(){
log.info(mySqlComplexConfig.getHost());
MySqlComplexConfig.UserInfo userInfo = mySqlComplexConfig.getUser();
return userInfo.toString();
}
}
上一篇:C语言的输入格式
下一篇:漫画:寻找无序数组的第k大元素
文章标题:服务注册发现、配置中心集一体的 Spring Cloud Consul
文章链接:http://soscw.com/index.php/essay/65369.html