SpringCloud Alibaba全集文章目录:
零、手把手教你搭建SpringCloudAlibaba项目
一、手把手教你搭建SpringCloud Alibaba之生产者与消费者
二、手把手教你搭建SpringCloudAlibaba之Nacos服务注册中心
三、手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心
四、手把手教你搭建SpringCloudAlibaba之Nacos服务集群配置
五、手把手教你搭建SpringCloudAlibaba之Nacos服务持久化配置
六、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量实时监控
七、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量控制
八、手把手教你搭建SpringCloudAlibaba之Sentinel服务降级
九、手把手教你搭建SpringCloudAlibaba之Sentinel热点key限流
十、手把手教你搭建SpringCloudAlibaba之Sentinel系统保护规则
十一、手把手教你搭建SpringCloudAlibaba之Sentinel服务熔断
十二、手把手教你搭建SpringCloudAlibaba之Sentinel规则持久化
十三、手把手教你搭建SpringCloudAlibaba之Seata分布式事务
点击跳转学习 -------------->手把手教你搭建SpringCloud项目
Nacos既然要作为配置中心,我们的配置肯定是要放在Nacos当中,具体怎么配置呢?
即在配置管理下的配置列表进行配置。点击右上角的+,进行添加配置。
Data ID :如何进行命名呢,命名的规则是什么呢?
配置规则为${prefix}-${spring.profile.active}.${file-extension}
prefix 默认为spring.applaction.name的值,也可以通过配置项spring.cloud.nacos.config.prefix来配置。
spring.profile.active 即为当前环境对应的profile,详情可以参考SpringBoot文档,注意:当spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId的拼接格式变为${prefix}.${spring.cloud.nacos.config.file-extension}
file-extension 为配置内容的数据格式,可以通过项spring.cloud.nacos.config.file-extension 来配置。目前只支持properties和yaml类型。
Nacos Spring Cloud 快速开始Nacos Spring Cloud 快速开始https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html
Nacos同Springcloudd-config一样,在项目初始化的时候,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。
springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于applaction。
我们首先就将我们生产者的服务的配置文件放到Nacos的配置列表当中。
1、加入配置中心所需要的jar包
com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-config
2、在Nacos当中新建配置文件,命令规则就是上边所说的规则。
贴出配置文件
server:
port: 8001 #服务端口
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource #当前数据源操作类型
driver-class-name: org.gjt.mm.mysql.Driver #数据库驱动包
url: jdbc:mysql://localhost:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
username: root
password: 123456
management:
endpoints:
jmx:
exposure:
include: '*'
#mybatis:配置
mybatis:
mapperLocations: classpath:dao/*.xml
type-aliases-package: com.buba.springcloud.pojo # 所有pojo别名类所在包
3、我们在resources下新建bootstrap.yml配置文件
spring:
application:
name: mcroservice-payment #服务名
cloud:
nacos:
config:
server-addr: localhost:8848
# 配置中心配置文件的后缀名格式
file-extension: yaml
# 是否动态刷新,默认为false
refresh: true
discovery:
server-addr: localhost:8848
# 当前环境对应的profile
profiles:
active: dev
我们的项目目录结构就成了
4、在我们启动类上加上注解
@RefreshScope 该注解支持nacos的动态刷新的功能,Springcloud原生的注解,实现配置自动更新
5、启动服务,在控制就可以看到我们的服务启动的时候加载了nacos数据,数据ID:“mcroservice-payment-dev.yaml”,组:“DEFAULT_GROUP”,对应的profile是dev,也读取到我们配置的端口号8081。
6、我们访问http://localhost:8001/payment/get/1,可以返回数据,说明我们的配置中心就配置成功啦。
有时候我们会在配置文件中配置一些信息,比如我们与第三方的集成的时候,会在配置文件加上对方的配置的域名、ip端口啥的,当这些信息发生改变的话,我们使用nacos的话就可以直接修改我们nacos中的配置文件,不用动我们项目中的配置,也不用重新打包、启动。
在PaymentControler的类上加上@RefreshScope注解,类中加入如下代码,看能否获取到我们新增的配置信息
@Value("${config.info}")
private String configInfo;
@GetMapping("/config/info")
public String getConfigInfo(){
System.out.println(configInfo);
return configInfo;
}
访问http://localhost:8001/config/info可以成功获取到我们刚刚配置的信息,如下图:
可以动态的刷新配置,那我们修改其配置的信息,看看不重启服务,会不会获取到修改后的信息。将端口修改成了8003。
在我们发布的时候,控制台也有日志记录,说我们config.info这个key发生了更改。
我们访问http://localhost:8001/config/info可以看到已经获取到我们修改的的端口8003。
1、一个大型分布式微服务会有很多的的微服务子项目,每个微服务项目又都有响应的开发环境、测试环境、正式环境,那怎么对这些微服务配置进行管理呢?
Nacos为我们提供了命令空间(NameSpace)+分组(Group)+dataid的分类设计思想,我们可以看到在Nacos的界面有命名空间,且有默认的值为public,是不能删除的,可以看到当前空间只有一个配置文件。
NameSpace主要是用来隔离的,比如我们不同的环境,就可以新建不同的命名空间,不同的命名空间是隔离的。
而看我们刚才的配置文件就是在public这个命名空间当中,且是默认的分组DEFAULT_GROUP,可以把不同的微服务划分到同一个分组中去。
那我们就接下来新建一个命名空间看一下,我们新建命名空间为test,可以看到dadataid是自动生成的,也可以自己写dadataid,是需要唯一的。
可以看到新的命名空间就新建成功了。
我们分别在test的命名空间下新建两个文件,分别在不同的分组下,如下图:
这是DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件
这是在DEV_GROUP下的 mcroservice-payment-dev.yaml配置文件
然后我们先测试一下再test命名空间下的DEV_GROUP分组下的mcroservice-payment-test.yaml的配置文件,如下图:
访问 http://localhost:8001/config/info,如下图,获取到了DEFAULT_GROUP默认分组下我们配置的info信息。
我们再测试一下再test命名空间下的DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件,如下图:
访问 http://localhost:8001/config/info,如下图,获取到了DEV_GROUP分组下我们配置的info信息。