Nacos全面解析

目录

一.Nacos概要

1.Nacos简介

2.Nacos安装

3.Nacos配置外部数据源

二.Nacos应用

1.注册发现

2.负载均衡

3.配置中心

4.多环境切换

5.配置刷新

6.共享/扩展配置

7.灰度发布


一.Nacos概要

1.Nacos简介

Nacos是阿里巴巴开源的一款支持 服务注册与发现配置管理服务管理 的组件。

取代以前常用的注册中心(zookeeper , eureka等等),以及配置中心(spring cloud config等等)

2.Nacos安装

1.下载安装包

官网地址:Releases · alibaba/nacos · GitHub 1.0

Releases · alibaba/nacos (github.com) 2.0

2.0.2下载地址:

链接:https://pan.baidu.com/s/1V4S1aNpgnj0h4GKlN5bnag 
提取码:0gyl

 说明:1.4.0以下使用的mysql驱动是8.0以下的,1.4.0以上使用的驱动就是8.0以上的了,所以大家在使用的nacos的时候要注意与mysql的对应版本问题,否则会因为nacos与mysql的版本不对应导致的nacos无法加载数据源。

2.解压使用启动脚本启动 

ps:直接启动可能会报错:java.net.UnknownHostException: jmenv.tbsite.net

默认是集群模式启动,如果报错可以按照如下方式启动

进入命令行执行:startup.cmd -m standalone 启动

也可以在application.properties中配置nacos.core.member.lookup.type=file

3.访问

nacos启动后访问控制台地址:http://localhost:8848/nacos/index.html#/login

用户名密码默认都是:nacos

3.Nacos配置外部数据源

修改D:\software\nacos-2.0.2\conf\application.properties

#下面这两行注释一定要打开,不打开下面配置的mysql数据源就不生效了
spring.datasource.platform=mysql
db.num=1

db.url.0=jdbc:mysql://localhost:3306/jg_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user=root
db.password=root

二.Nacos应用

1.注册发现

1.项目中引入nacos的相关依赖

        <!--nacos-discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.2.5.RELEASE</version>
        </dependency>
        <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.2.5.RELEASE</version>
        </dependency>

2.配置文件如下

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

3.启动类加服务发现的注解

@SpringBootApplication
@EnableDiscoveryClient
public class NacosDemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(NacosDemoApplication.class, args);
    }

}

4.查看nacos界面,服务列表

注意:可以通过在配置文件中配置namespace 属性控制服务属于哪个命名空间下的,默认不配置namespace都是在public的命名空间下,可以在命令空间菜单下新建命名空间。(namespace 是通过id与nacos命名空间 关联的,命名空间可是实现数据隔离)

5.测试

localhost:10086/nacos/hellohttp://localhost:10086/nacos/hello调用controller接口正确返回,说明服务注册和发现正常

2.负载均衡

1.初始化负载均衡算法

@Configuration
public class NacosDemoConfig {
    /***
     * Nacos负载均衡算法
     * @return
     */
    @Bean
    @Scope(value="prototype")
    public IRule loadBalanceRule(){
        return new NacosRule();
    }
}

2.在配置文件中配置权重 weight: 1

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        namespace: public
        server-addr: 127.0.0.1:8848
        weight: 1

3.再起一个服务权重设置为weight: 2

-Dserver.port=10087 -Dspring.cloud.nacos.discovery.weight=2

4.启动后查看控制台

 5.通过网关测试,发现调用比例为1:2

3.配置中心

需要把配置文件名称改为优先加载的bootstrap.yaml文件,否则加载不到nacos的配置

1.新建命名空间nacos-demo(实现数据隔离)id为2,配置文件中指定namespace为2

配置服务名称:name: nacos-demo

配置文件后缀名:file-extension: yaml

spring:
  application:
    name: nacos-demo
  cloud:
    nacos:
      discovery:
        namespace: 2
        server-addr: 127.0.0.1:8848
        weight: 1
      config:
        server-addr: 127.0.0.1:8848
        namespace: 2
        file-extension: yaml

2.在配置管理>配置列表中新建配置

(1)Data_id默认加载${spring.application.name}.${file-extension}(服务名.文件后缀)

 3.项目中使用配置

@RestController
@RequestMapping("/nacos")
public class NacosDemoController {

    @Value("${nacostest}")
    private String nacostest;

    @GetMapping("hello")
    public String helloNacos(){
        return "Hello Nacos:"+nacostest;
    }

}

4.测试

http://localhost:10086/nacos/hello

 返回成功,配置数据生效。

4.多环境切换

通过配置Data Id实现多环境切换

配置格式为:服务名-环境.文件后缀

${spring.application.name}-${profile}.${file-extension:properties}

1.配置开发环境配置文件如下

 2.工程配置文件中指定环境配置

spring:
  application:
    name: nacos-demo
  profiles:
    active: dev

3.测试

    @Value("${nacosenv}")
    private String nacosenv;

    @GetMapping("hello")
    public String helloNacos(){
        return "Nacos Env is:"+nacosenv;
    }

4.访问成功,环境配置完成

5.配置刷新

默认情况下nacos已经实现了自动配置刷新功能,如果需要刷新配置直接在控制器中加入@RefreshScope注解即可

6.共享/扩展配置

(1)创建一个public.yaml作为共享配置

(2)在工程配置文件中引入共享配置       

shared-configs[0]:
          dataId: public.yaml
          refresh: true

spring:
  application:
    name: nacos-demo
  profiles:
    active: dev
  cloud:
    nacos:
      discovery:
        namespace: 2
        server-addr: 127.0.0.1:8848
        weight: 1
      config:
        server-addr: 127.0.0.1:8848
        namespace: 2
        file-extension: yaml
        shared-configs[0]:
          dataId: public.yaml
          refresh: true

 (3)测试

        获取public.yaml内容成功,共享配置生效

7.灰度发布

1.概述

        Nacos支持以IP为粒度的灰度配置

2.灰度发布配置步骤:

(1)讲服务在不同的服务器部署,有多个实例

(2)编辑配置文件点击Beta发布

(3)填写需要发布到的ip,以逗号分割

(4)点击【发布Beta】,点击后,可以通过【停止Beata】按钮停止灰度发布

 

  • 6
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Nacos 是一个开源的分布式配置中心和服务发现框架,它提供了服务注册、发现、配置管理等功能。下面是对 Nacos 源码的简要分析: 1. 项目结构:Nacos 代码库主要包括 core 模块、config 模块、discovery 模块等。core 模块提供了核心的数据结构和服务注册与发现的功能,config 模块实现了配置管理相关的功能,discovery 模块实现了服务发现的功能。 2. 注册与发现:Nacos 使用了基于 Raft 算法的一致性协议来实现注册与发现功能。核心模块中的 ServerListManager 负责管理服务列表的变更和更新,InstanceEventProcessor 负责处理服务实例事件。服务注册和发现的过程涉及到数据存储和同步,涉及到的类有 LocalServerData、MetadataManager、SnapshotManager 等。 3. 配置管理:Nacos 的配置管理功能由 config 模块实现。核心类是 ConfigServiceImpl,它负责处理配置的读写和监听。在配置写入时,会通过 ConfigChangePublisher 将变更发布给订阅者。ConfigChangeListeners 负责处理配置变更事件。 4. 数据存储:Nacos 的数据存储使用了内置的嵌入式数据库 Derby。Derby 提供了基于文件的持久化存储,用于存储配置数据、注册数据等。 5. 服务路由:Nacos 通过实现了 LoadBalancer 接口来实现服务路由的功能。LoadBalancer 负责选择可用的服务实例,实现了负载均衡的策略。 这只是对 Nacos 源码的简要分析,Nacos 的源码结构比较复杂,涉及到的技术栈也比较丰富。如果你对具体的实现细节有更多的疑问,可以参考 Nacos 的官方文档或者深入阅读源码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr Tang

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值