微服务架构-SpringCloudAlibaba-095:基于Naocs构建分布式配置中心

1 Nacos课程基本回顾

课程内容:

  1. 基于Nacos实现分布式配置中心
  2. Nacos如何实现数据持久化
  3. Nacos集群部署的设计原理
  4. Nacos与Eureka实现注册中心的原理

2 分布式配置中心产生的背景

在项目中定义配置文件,最大的缺陷?
如果在生产环境正在运行的时候突然需要修改配置文件,必须重启服务器。
定义配置规范:前面必须加上团队名称。

分布式配置中心的概念?
使用专门的服务器统一存放管理整个微服务的配置文件,能够完全动态实现对配置文件修改、新增,不需要重启服务器。
常见的配置中心:携程的阿波罗(比较重)、SpringCloud Config(没有界面)、Nacos(轻量级)等。
轻量级/重量级:部署、架构设计原理、体量、学习成本等方面;

3 分布式配置中心架构原理

分布式配置中心实现原理:

  1. 本地应用读取云端分布式配置中心文件(第一次建立长连接);
  2. 本地应用读取到配置文件之后,本地jvm和硬盘中都会缓存一份;
  3. 本地应用与分布式配置中心服务器端一直保持长连接;
  4. 当配置文件发生变化(使用MD5/版本号进行区分),将变化结果通知给本地应用及时刷新配置文件,完全百分百实现动态修改配置文件。

如何判断配置文件是否发生变化?采用版本控制或者对整个文件做MD5比较。
在这里插入图片描述
注意:Nacos分布式配置中心和注册中心都部署在同一个应用,就是一个单体的应用。

4 将配置文件发布Nacos配置中心

Nacos使用配置中心的发布规则
Data ID:默认情况下 服务名称-版本.yaml/properties
版本:dev、test、pre、prd等。

服务器端
在这里插入图片描述

5 本地应用读取Nacos配置中心

客户端
引入maven依赖

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.0.RELEASE</version>
</parent>
<dependencies>
    <!--  springboot 整合web组件-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- macos 整合注册中心-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        <version>0.2.2.RELEASE</version>
    </dependency>
    <!-- nacos 整合config-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        <version>0.2.2.RELEASE</version>
    </dependency>
</dependencies>

bootstrap.yml

spring:
  application:
    ###服务的名称
    name: mayikt-nacos-client-95
  cloud:
    nacos:
      discovery:
        ###nacos注册地址
        server-addr: 127.0.0.1:8848
        enabled: true
      config:
        ###配置中心连接地址
        server-addr: 127.0.0.1:8848
        ###分组
        group: DEFAULT_GROUP
        ###类型 默认加载properties,可以手动设定加载yaml
        file-extension: properties

注意事项:nacos如果本地有相同配置的话,可能在启动的时候抛出异常。

bootstrap.yml与application.yml区别?
bootstrap.yml属于整个应用程序配置,最先被加载;
application.yml由Spring ApplicationContext加载。

@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);
    }
}

@RefreshScope注解可以实现动态刷新配置文件。
测试结果:
在这里插入图片描述

6 Nacos实现多环境不同配置

多版本控制
分别在nacos服务器端创建
mayikt-nacos-client-dev.yaml
mayikt-nacos-client-prd.yaml
客户端指定读取版本
spring.profiles.active=dev/prd
在这里插入图片描述

7 Nacos配置中心集群部署&持久化

Nacos配置中心集群部署 数据持久化到MySQL服务器

数据持久化
默认的情况下,分布式配置中心的数据存放到本地data目录下,但是这种情况如果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_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=root

摘自官网: https://nacos.io/zh-cn/docs/deployment.html
测试效果:
在这里插入图片描述

8 基于Nginx实现Nacos集群部署

相关集群配置
创建cluster文件夹,下层分别创建文件夹
—nacos-server-8848
—nacos-server-8849
—nacos-server-8850
修改/conf目录cluster.conf.example为cluster.conf,内容为
###ip和端口号
127.0.0.1:8848
127.0.0.1:8849
127.0.0.1:8850
分别启动3个nacos,修改hosts文件(C:\Windows\System32\drivers\etc)
127.0.0.1 nacos.mayikt.com

Nginx相关配置

http {
    include       mime.types;
    default_type  application/octet-stream;

    upstream mayiktnacosaddr {
	server 127.0.0.1:8848;
	server 127.0.0.1:8849;
	server 127.0.0.1:8850;
	}
    server {
        listen       80;
        server_name  nacos.mayikt.com;
        location /nacos/ {
            proxy_pass   http://mayiktnacosaddr/nacos/;
        }
    }
}

在这里插入图片描述
测试效果:
在这里插入图片描述
客户端连接
server-addr: 127.0.0.1:8848,127.0.0.1:8849,127.0.0.1:8850
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值