- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章springcloud使用consul作为配置中心由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
spring cloud 中文手册:https://springcloud.cc/spring-cloud-consul.html 。
也就是说在我们使用consul config时最好在consul 建立相应的目录结构 适用于某一个服务的目录结构以及适用于所有的服务的目录结构 。
本列consul web ui :springboot为我们提供了三种环境dev:默认开发环境 test:测试环境 prod:生产环境 。
ps
1.每次当我们修改consul上面的配置信息的时候,会向我们的代码发送一个/refresh请求刷新我们的工程,通过使我们的取值动态的刷新,不需要重启项目, 但是当我们使用@value进行取值的时候,虽然可会取到值也会刷新项目但是不会更改我们的取值,还是取到项目启动时候配置在consul上面的值,实时刷新.
2.当我们在全局的application的文件中配置跟某一个服务列如:server-sms中配置相同的属性时, server-sms这个项目启动的时候默认是先去找自己目录下面的配置,再去找全局的配置,如果自己目录下 。
实战:
pom.xml文件配置:
1
2
3
4
|
<dependency>
<groupid>org.springframework.cloud</groupid>
<artifactid>spring-cloud-starter-consul-config</artifactid>
</dependency>
|
bootstarp.xml配置:(如果配置在application里面,他不会生效,bootstrap.yml先比applciation.properties加载) 。
1
2
3
4
5
6
7
8
9
10
11
|
spring:
cloud:
consul:
host:
100.1
.
00.0
#host:
00.0
.
100.200
port:
8500
enabled:
true
config:
enabled:
true
#默认是
true
--
format: yaml # 表示consul上面文件的格式 有四种 yaml properties key-value files
data-key: configuration #表示consul上面的key值(或者说文件的名字) 默认是data
|
format举例说明两种(本列中使用的是server-sms项目的yaml):
properties:
yaml:
取值方式:
1.通过enabledconfigurationproperties注解取值(启动项目后修改consul上的属性值,项目中的属性值立即发生变化):
对应的bean:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
//name要与consul上面的name写的一样,consul上面可以写多级目录 例如: userinfo: name: liaowenwen
//对应的写configurationproperties(prefix="userinfo ") 如果项目使用中配置化东西比较多 建议采用这种形式
@configurationproperties
()
public
class
userinfo {
private
string name;
//要与consul上面一致
public
string getname() {
return
name;
}
public
void
setname(string name) {
this
.name = name;
}
|
controller代码取值:
1
2
3
4
5
6
7
8
|
@autowired
private
userinfo userinfo;
@apioperation
(value=
"获取consulinfo"
, notes=
"获取consulinfo"
)
public
string getconsulinfo() {
return
userinfo.getname();
}
|
项目启动类:
1
2
3
4
5
6
|
@springbootapplication
@enablediscoveryclient
@enableconfigurationproperties
({userinfo.
class
})
public
class
application {
public
static
void
main(string[] args){
springapplication.run(application.
class
,args);}
|
2.通过value注解取值(项目启动后修改consul上的值,项目中的值不发生变化,只有再次启动项目获取的值才是修改后的值,发送/refresh请求无效) 。
1
2
3
4
5
6
7
8
|
@value
private
string name;
@apioperation
(value=
"获取consulinfo"
, notes=
"获取consulinfo"
)
public
string getconsulinfo(){
return
name;
}
|
3.static 取值 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
@component
@configuration
public
class
consulkv {
public
static
string smsurl;
public
static
string username;
public
static
string password;
@value
(
"${ssbp.smsurl}"
)
public
void
setsmsurl(string smsurl) {
consulkv.smsurl = smsurl;
}
@value
(
"${ccb.job.login.username}"
)
public
void
setusername(string username) {
consulkv.username = username;
}
@value
(
"${ccb.job.login.password}"
)
public
void
setpassword(string password) {
consulkv.password = password;
}
|
示例代码地址: https://github.com/liaowenn/spring-cloud-consul-config 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/xiaonuo717/article/details/73289178 。
最后此篇关于springcloud使用consul作为配置中心的文章就讲到这里了,如果你想了解更多关于springcloud使用consul作为配置中心的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
前置内容 (1)、微服务理论入门和手把手带你进行微服务环境搭建及支付、订单业务编写 (2)、SpringCloud之Eureka服务注册与发现 (3)、SpringCloud之Zookeeper进行服
SpringCloud-实用篇 API:RestTemplate 跨服务调用的api 创建一个bean @Bean @LoadBalanced //负载均衡 public RestTemplate
微服务学习计划——SpringCloud 在学习并掌握了众多基础框架之后,我们的项目繁杂且难以掌握,那么我们就需要开启一门新的课程,也就是我们常说的微服务架构 随着互联网行业的发展,对服
目录 SpringCloud @FeignClient 参数详解 @FeignClient 注解常用参数 SpringCloud @FeignClient
Config 介绍 Spring Cloud Config项目是一个解决分布式系统的配置管理方案。它包含了Client和Server两个部分,server提供配置文件的存储、以接口的形式将配置文件
gateway跨域配置 gateway允许跨域的配置和zuul的不一样,记录一下。 版本 ?
SpringCloud 提取公共配置 在开发微服务项目时,通常会有很多服务,此时会用配置中心来管理这些服务的配置,但有些服务可能会有相同的配置,比如数据源配置,eureka server注册中心地
1、场景简述 笔者最近用到SpringCloud 服务网关的时候,进行服务网关的路由测试,发现无法路由自己设置的规则,测试的时候如下 通过错误排查发现,原来是路由规则写错了! 路由规则如
现在基于SpringCloud的微服务开发日益流行,网上各种开源项目层出不穷。我们在实际工作中可以参考开源项目实现很多开箱即用的功能,但是必须要遵守一定的约定和规范。 本文结合我们实际的开发中遇到
Feign传参注意 最近在用SpringCloud尝试重构以前的项目,使用Feign客户端组件来调用微服务,经常出现参数传不过去变成null的问题,网上查了一下发现feign在参数上的使用还是有一
SpringCloud 服务注册IP错误 1、错误原因 在服务注册的时候,是使用 spring.cloud.client.ipAddress 这个变量,如果本机有多个网卡,那么可能会把不是本机以
简介: gateway主要是做路由 负载,过滤 主要是替代zuul 1.x 性能比zuul好 zuul是基于 Servlet ,gateway是基于spring-webflux 用的netty+
1、场景 笔者就Zuul网关下实现其负载均衡与熔断机制(雪崩)进行实践,前提是已经导入zuul相关依赖 springboot版本:1.5.9.RELEASE springcloud版本:Da
版本说明 开源软件 版本 springboot 2.1.6.RELEASE jdk
今天做项目的时候,遇到一个问题,如果我调用某个服务的接口,但是这个服务挂了,同时业务要求这个接口的结果是必须的,那我该怎么办呢,答案是通过hystrix,但是又有一点,服务不是平白无故挂的(排除服务
前言 eureka是一种基于rest(具像状态传输)的服务,主要用于aws云中定位服务,以实现中间层服务器的负载平衡和故障转移。本文记录一个简单的服务注册与发现实例。 github地址:http
前言 zuul 是在spring cloud netflix平台上提供动态路由,监控,弹性,安全等边缘服务的框架,是netflix基于jvm的路由器和服务器端负载均衡器,相当于是设备和 netfl
简介 Zuul是Spring Cloud全家桶中的微服务API网关。 所有从设备或网站来的请求都会经过Zuul到达后端的Netflix应用程序 Zuul 主要提供路由(请求转发)和
简介 在分布式系统中,服务与服务之间依赖错综复杂,一种不可避免的情况就是某些服务将会出现失败。Hystrix是一个库,它提供了服务与服务之间的容错功能,主要体现在延迟容错和容错,从
简介 feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service。Spring Cloud集成了Ribbon和Eureka,
我是一名优秀的程序员,十分优秀!