上一篇:怎样构建一个微服务项目? | 带你读《Spring Cloud Alibaba(2019)》之六
下一篇:如何基于Nacos集群部署方案? | 带你读《Spring Cloud Alibaba(2019)》之八
本文来自于《精通Spring Cloud Alibaba》课程的整理,讲师为余胜军,点击查看视频内容。
本文系志愿者整理,供配合学习中心课程使用,不做商业用途。
分布式配置中心
Nacos是阿里巴巴开源开源框架。
所解决的问题是:注册中心| 分布式配置中心。
可以替代之前学习Eureka和SPringConfig | 携程阿波罗
IP:端口号/调用方法加名称+参数
192.168.212.110:8080/getUser
分布式配置中心产生的背景?
在项目中定义配置文件,最大的缺陷是什么?
如果在生产环境正在运行的时候突然需要修改配置文件的话,必须重启我们的服务器。
定义配置规范:前面一定加上团队名称。
轻量级与重量级分别表示什么意思?
轻量级:部署、架构设计原理都比较简单,学习成本也是比较低:
重量级:部署、架构设计、体量都是非常大,学习成本是比较高。
如何判断配置文件是否发生变化:采用 版本 | MD5。
分布式配置中心实现原理:
1、本地应用读取我们云端分布式配置中心文件(第一次建立长连接)
2、本地应用读取到配置文件之后,本地jvm和硬盘中都会缓存一份。
3、本地应用与分布式配置中心服务器端一直保持长连接。
4、当我们的配置文件发生变化(MD5 | 版本号)实现区分,将变化的结果通知给我们的本地应用及时的刷新我们的配置文件。
完全百分百实现动态化修改我们的配置文件。
注意:Nacos分布式配置中心和注册中心都部署在同一个应用,就是一个单体的应用。
分布式配置中心的作用
分布式配置中心可以实现不需要重启我们的服务器,动态的修改我们的配置文件内容,
常见的配置中心有携程的阿波罗、SpringCloud Config、Nacos轻量级的配置中心等。
基于Nacos实现分布式配置中心
服务器端
Nacos使用配置中心的发布规则:
Dataid名称:默认的情况服务名称-版本.yaml | properties形式
版本:dev、test、pre、prd等。
客户端
引入依赖:nacos整合config
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>0.2.2.RELEASE</version>
创建一个bootstrap.yml
注意事项:
nacos本地如果也配置的话,可能在启动的时候会抛出异常。
spring:
application:
###服务的名称
name: meitemayikt-nacos-client
cloud:
nacos:
discovery:
###nacos注册地址
server-addr: 127.0.0.1:8848
enabled: true
config:
###配置中心连接地址
server-addr: 127.0.0.1:8848
###分组
group: DEFAULT_GROUP
###类型
file-extension: yaml
@RestController
@SpringBootApplication
@RefreshScope
public class NacosController {
@Value("${mayikt.name}")
private String userName;
@RequestMapping("/getConfig")
public String getConfig() {
return userName;
}
public static void main(String[] args) {
SpringApplication.run(NacosController.class);
}
}
注意:连接nacos分布式配置中心一定采用bootstrap形式优先加载 否则可能会报错。
bootstrap与application的区别:
bootstrap.yml 用于应用程序上下文的引导阶段。application.yml 由父Spring ApplicationContext加载。
可以实现动态实现@RefreshScope;可以对配置内容进行监听,察觉到内容被编辑之后会立刻刷新,而不用重启服务器。
修改配置内容:
多版本控制
分别在nacos服务器端创建
meitemayikt-nacos-client-dev.yaml
meitemayikt-nacos-client-prd.yaml
客户端指定读取版本
运行结果展示:
数据持久化
找到配置文件config:创建数据库表mysql,然后连接到properties.
第一步:新建数据库
然后将sql文档里面的内容复制在查询框里面执行一下。这几张表就有了。
插入一个用户信息:
执行结果:
最后,连接数据库:
登录测试:用户名:mayikt,密码:nacos。
可以看到:切换数据源之后,之前的数据都看不到了。可以再次新建配置:
点击发布之后,配置的内容自动保存在数据库了。
注意:
默认的情况下,分布式配置中心的数据存放到本地data目录下,但是这种情况如果nacos集群的话无法保证数据的同步性。
在0.7版本之前,在单机模式时nacos使用嵌入式数据库实现数据的存储,不方便观察数据存储的基本情况。0.7版本增加了支持mysql数据源能力,具体的操作步骤:
1.安装数据库,版本要求:5.6.5+
2.初始化mysql数据库,数据库初始化文件:nacos-mysql.sql
3.修改conf/application.properties文件,增加支持mysql数据源配置(目前只支持mysql),添加mysql数据源的url、用户名和密码。
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=root