本文主要是介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望...
前言
老牌注册中心Eureka停更运维,新型的consul、nacos崛起,本文介绍consul服务
一、consul是什么?
Consul 是一套开源的分布式服务发China编程现和配置管理系统,由 HashiCorp 公司用 Go 语言开发。
提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之Consul提供了一种完整的服务网格解决方案。它具有很多优点。包括: 基于 raft 协议,比较简洁; 支持健康检查, 同时支持 HTTP 和 DNS 协议 支持跨数据中心的 WAN 集群 提供图形界面 跨平台,支持 linux、MAC、Windows
作用:
- 服务发现:提供HTTP和DNS两种发现方式
- 健康监测:支持多种方式,HTTP、TCP、docker、Shell脚本定制化监控
- KV存储:Key、Value的存储方式。
- 多数据中心:Consul支持多数据中心
可视化Web界面
- consul官网地址:http://www.consul.io
- spring consul:http://docs.spring.io/spring-cloud-consul/docs/current/reference/html/
二、安装运行consul
下载地址:http://developer.hashicorp.com/consul/install
编程下载完成后只有一个.exe文件,在该目录下打开cmd,输入 consul agent -dev 使用开发者模式启动consul
最后在 localhost:8500访问
访问结果:
三、使用
1、服务发现
将微服务注册到consul服务中心中统一管理
1)在需要注册的服务的pom文件中引入依赖:
<!--SpringCloud consul discovery --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-consul-discovery</artifactId> </dependency>China编程;
注意:引入该依赖的同时也引入了loadbalancer(负载均衡),若使用的远程调用方式为RestTemplate,需要在创建RestTemplate的配置类中对应Bean的位置加上@LoadBalanced注解,支持负载均衡
@Bean @LoadBalanced //按服务名称调用时默认负载均衡 要加上该注解支持负载均衡 public RestTemplate restTemplate(){ return new RestTemplate(); }
2)配置yaml
spring: application: name: cloud-consumer-order cloud: consul: port: 8500 host: localhost discovery: prefer-ip-address: true #优先使用服务ip进行注册 service-name: ${spring.application.name}
3)主启动类添加注解:@EnableDiscoveryClient //**服务注册和发现
4)启动主启动类,访问8500端口查看
注册成功
2、配置管理
通用配置配置在consul,每个服务从consul获取配置,也可接受动态刷新
1)服务端加入依赖,调用端不切换配置环境可以不配置到consul
<!--SpringCloud consul config--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-consul-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bootstrap</artifactId> </dependency>
2)新增配置文件bootstrap.yml
- applicaiton.yml是用户级的资源配置项
- bootstrap.yml是系统级的,优先级更加高
Spring Cloud会创建一个“Bootstrap Context”,作为Spring应用的`Application Context`的父上下文。初始化的时候,`Bootstrap Context`负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的`Environment`。
`Bootstrap`属性有高优先级,默认情况下,它们不会被本地配置覆盖。 `Bootstrap context`和`Application Context`有着不同的约定,所以新增了一个`bootstrap.yml`文件,保证`Bootstrap Context`和`Application Context`配置的分离。
application.yml文件改为bootstrap.yml,这是很关键的或者两者共存
因为bootstrap.yml是比application.yml先加载的。bootstrap.yml优先级高于application.yml
- bootstrap.yml:
spring: application: name: cloud-payment-service ####Spring Cloud Consul for Service Discovery cloud: consul: host: localhost port: 8500 discovery: service-name: ${spring.application.name} config: profile-separator: '-' # default value is ",",we update '-' format: YAML
3)在consul中创建配置文件
以config文件夹开始,data文件结束,中间文件夹以服务名称-配置环境命名 (不写为默认环境)
# config/cloud-payment-service/data # /cl编程oud-payment-service-dev/data # /cloud-payment-service-prod/data
4)动态刷新
在主启动类上加入 @RefreshScope 注解,这样在consul中更改配置后,响应配置会在服务端刷新
四、数据持久化
问题:我们配置的配置文件,当consul服务退出后就消失了,要将配置的文件持久化到本地,并开机的时候自动启动consul服务
1、在consul安装目录新建一个mydata文件夹存放配置的数据
2、新建一个consul_start.txt文件
文件内容:
其中写明consul.exe文件位置和刚创建的mydata文件夹位置。其中mydata后要有空格
@echo.服务启动...... @echo off @sc create Consul binpath= "D:\wtp\software\cloud\consul\consul.exe agent -server -ui -bind=127.0.0.1 -client=0.0.0.0 -bootstrap-expect 1 -data-dir D:\wtp\software\cloud\consul\mydata " @net start Consul @sc config China编程Consul start= AUTO @echo.Consul start is OK......success @pause
3、文件 consul_start.txt 保存后后缀改为.BAT
4、以管理员身份运行 consul_start.txt
效果:
总结
本文介绍了consul的安装、使用、持久化。
这篇关于SpringCloud之consul服务注册与发现、配置管理、配置持久化方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!