Nacos 手摸手教程

沙海 2022年5月11日08:50:28Java评论63字数 6856阅读22分51秒阅读模式
摘要

Nacos 手摸手教程 敖丙

Nacos 手摸手教程

敖丙 文章源自JAVA秀-https://www.javaxiu.com/65121.html

以下文章来源于悟空聊架构,作者悟空聊架构文章源自JAVA秀-https://www.javaxiu.com/65121.html

文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

悟空聊架构.文章源自JAVA秀-https://www.javaxiu.com/65121.html

用故事讲解分布式、架构。 《 JVM 性能调优实战》专栏作者, 《Spring Cloud 实战 PassJava》开源作者, 自主开发了 PMP 刷题小程序。文章源自JAVA秀-https://www.javaxiu.com/65121.html

文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 作为服务注册中心、配置中心,已经非常成熟了,业界的标杆,在讲解 Nacos 的架构原理之前,我先给大家来一篇开胃菜:讲解 Nacos 如何使用。文章源自JAVA秀-https://www.javaxiu.com/65121.html

涉及到如下两个话题:文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 用 Nacos 作为注册中心。文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 用 Nacos 作为配置中心。文章源自JAVA秀-https://www.javaxiu.com/65121.html

由于本篇是针对 Nacos 的使用和配置教程,可能会略显枯燥,建议大家快速浏览一遍,然后收藏转发下,以后说不定就会用上了~~文章源自JAVA秀-https://www.javaxiu.com/65121.html

本篇主要内容如下:文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

老规矩,本篇所有示例代码都是用我的开源 SpringCloud 项目 PassJava 作为示例。文章源自JAVA秀-https://www.javaxiu.com/65121.html

开源地址: https://github.com/Jackson0714/PassJava-Platform文章源自JAVA秀-https://www.javaxiu.com/65121.html

喜欢的小伙伴来点个 Star 吧,冲 2K Star。文章源自JAVA秀-https://www.javaxiu.com/65121.html

PassJava 架构图如下所示:文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 是阿里巴巴开源的一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。文章源自JAVA秀-https://www.javaxiu.com/65121.html

一、Nacos 作为注册中心

1.1 引入 Nacos 服务发现组件

passjava-common模块的pom.xml文件引入Nacos 服务发现组件文章源自JAVA秀-https://www.javaxiu.com/65121.html

<!-- nacos discovery 服务发现组件--><dependency>    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

1.2 下载 Nacos Server 工具包并启动

注意:我在 Windows 和 Mac 上都测试过,都可以正常使用。文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 下载Nacos Server 压缩包文章源自JAVA秀-https://www.javaxiu.com/65121.html

https://github.com/alibaba/nacos/releases文章源自JAVA秀-https://www.javaxiu.com/65121.html

启动 Server,进入解压后文件夹或编译打包好的文件夹,找到如下相对文件夹 nacos/bin,并对照操作系统实际情况之下如下命令。文章源自JAVA秀-https://www.javaxiu.com/65121.html

  1. Linux/Unix/Mac 操作系统,执行命令 sh startup.sh -m standalone文章源自JAVA秀-https://www.javaxiu.com/65121.html

  2. Windows 操作系统,执行命令 cmd startup.cmd文章源自JAVA秀-https://www.javaxiu.com/65121.html

windows执行startupm.cmd遇到问题:文章源自JAVA秀-https://www.javaxiu.com/65121.html

λ startup.cmd                                                       Please set the JAVA_HOME variable in your environment, We need java(x64)! jdk8 or later is better! 

解决方案:文章源自JAVA秀-https://www.javaxiu.com/65121.html

修改startup.cmd文件中的 %JAVA_HOME%文章源自JAVA秀-https://www.javaxiu.com/65121.html

%JAVA_HOME% 替换为 C:\Program Files\Java\jdk1.8.0_131

启动成功:文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

1.3 每个微服务都配置 Nacos Server 地址

  • 配置Nacos Server 地址文章源自JAVA秀-https://www.javaxiu.com/65121.html

在passjava-question、passjava-channel、passjava-content、passjava-member、passjava-study 应用的 /src/main/resources/application.yml配置文件中配置 Nacos Server 地址文章源自JAVA秀-https://www.javaxiu.com/65121.html

spring:   cloud:    nacos:      discovery:        server-addr: 127.0.0.1:8848

1.4 添加注解

为每个服务使用 @EnableDiscoveryClient 注解开启服务注册与发现功能文章源自JAVA秀-https://www.javaxiu.com/65121.html

@EnableDiscoveryClient@MapperScan("com.jackson0714.passjava.question.dao")@SpringBootApplicationpublic class PassjavaQuestionApplication {    public static void main(String[] args) {        SpringApplication.run(PassjavaQuestionApplication.class, args);    }}

1.5 配置微服务的名称

spring:  application:    name: passjava-question

1.6 访问nacos server后台

  • 登录后台文章源自JAVA秀-https://www.javaxiu.com/65121.html

http://localhost:8848/nacos/index.html#/login文章源自JAVA秀-https://www.javaxiu.com/65121.html

用户名:nacos文章源自JAVA秀-https://www.javaxiu.com/65121.html

密码:nacos文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 查看已注册的服务文章源自JAVA秀-https://www.javaxiu.com/65121.html

    passjava-channel 渠道微服务passjava-member 用户微服务passjava-study 学习微服务passjava-question 问题微服务passjava-content 内容微服务

    Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

二、Nacos 作为配置中心

2.1 传统配置方式

  • application.properties文件中定义两个配置:文章源自JAVA秀-https://www.javaxiu.com/65121.html

member.nickname = "悟空聊架构"member.age = "18"
  • 示例控制器中定义私有变量nickname和age,@value代表从配置中取值文章源自JAVA秀-https://www.javaxiu.com/65121.html

@Value("${member.nickname}")private  String nickname;@Value("$member.age")private  Integer age;
  • 示例控制器中定义方法:获取nick和age的值文章源自JAVA秀-https://www.javaxiu.com/65121.html

@RequestMapping("/test-local-config")public R testLocalConfig() {    return R.ok().put("nickname", nickname).put("age", age);}
  • 测试结果文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

mark文章源自JAVA秀-https://www.javaxiu.com/65121.html

总结:从配置文件中获取配置。文章源自JAVA秀-https://www.javaxiu.com/65121.html

这种方式的缺点是什么呢?如果要修改配置参数,则需要重新启动服务。如果服务很多,则需要重启所有服务,非常不方便。文章源自JAVA秀-https://www.javaxiu.com/65121.html

有没有什么办法不停服务修改配置而且使其生效呢?文章源自JAVA秀-https://www.javaxiu.com/65121.html

答案:有的,用Spring Cloud Alibaba的Nacos 组件就可以完成。文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.2 引入Nacos依赖

PassJava-Common项目的pom.xml文件引入Spring Cloud Alibaba Nacos Config依赖文章源自JAVA秀-https://www.javaxiu.com/65121.html

<dependency>    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>

2.3 配置Nacos元数据

  • passjava-member 添加 /src/main/resources/bootstrap.properties 配置文件(注意:bootstrap.properties 优先级高于其他配置文件)文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 配置 Nacos Config 元数据文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

bootstrap.properties文章源自JAVA秀-https://www.javaxiu.com/65121.html

spring.application.name=passjava-memberspring.cloud.nacos.config.server-addr=127.0.0.1:8848

2.4 Nacos后台新增配置

Data ID: passjava-member.properties文章源自JAVA秀-https://www.javaxiu.com/65121.html

Group: DEFAULT_GROUP文章源自JAVA秀-https://www.javaxiu.com/65121.html

配置格式:文章源自JAVA秀-https://www.javaxiu.com/65121.html

member.nick="悟空"member.age=10

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos后台新增配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.5 开启动态刷新配置功能

添加注解@RefreshScope开启动态刷新配置功能文章源自JAVA秀-https://www.javaxiu.com/65121.html

@RefreshScope@RestController@RequestMapping("member/sample")public class SampleController {}

可以从控制台看到日志信息:文章源自JAVA秀-https://www.javaxiu.com/65121.html

Refresh keys changed: [member.age]2020-04-19 23:34:07.154 INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData : [fixed-127.0.0.1_8848] [notify-ok] dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b 2020-04-19 23:34:07.154 INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData : [fixed-127.0.0.1_8848] [notify-listener] time cost=529ms in ClientWorker, dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b

member.age 更新了,通知了member服务,刷新了配置。对应的配置id为passjava-member.properties,分组为DEFAULT_GROUP。监听器为com.alibaba.cloud.nacos.refresh.NacosContextRefresher文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.6 测试结果

访问:http://localhost:10000/member/sample/test-local-config文章源自JAVA秀-https://www.javaxiu.com/65121.html

结果:nickname和age和Nacos后台配置一致文章源自JAVA秀-https://www.javaxiu.com/65121.html

结论:只用在Nacos后台改配置即可实时修改配置。文章源自JAVA秀-https://www.javaxiu.com/65121.html

注意:Nacos的配置项优先级高于application.propertite里面的配置。文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

测试结果文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.7 命名空间

我们现在有5个微服务,每个微服务用到的配置可能都不一样,那不同微服务怎么样获取自己微服务的配置呢?文章源自JAVA秀-https://www.javaxiu.com/65121.html

这里可以用到命名空间,我们针对每个微服务,都创建一个命名空间。文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 创建命名空间文章源自JAVA秀-https://www.javaxiu.com/65121.html

    Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

    创建命名空间文章源自JAVA秀-https://www.javaxiu.com/65121.html

# 创建5个命名空间passjava-channelpassjava-contentpassjava-memberpassjava-questionpassjava-study

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

命名空间文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 命名空间下创建配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

    我们打开配置列表菜单,可以看到有五个命名空间。文章源自JAVA秀-https://www.javaxiu.com/65121.html

    Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

    命名空间下创建配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

选中passjava-channel命名空间,然后新增配置项,与之前新增配置的步骤一致,也可以通过克隆命名空间来克隆配置。文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

克隆配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 修改指定的命名空间文章源自JAVA秀-https://www.javaxiu.com/65121.html

    bootstrap.properties配置命名空间文章源自JAVA秀-https://www.javaxiu.com/65121.html

    spring.cloud.nacos.config.namespace=passjava-member
    文章源自JAVA秀-https://www.javaxiu.com/65121.html
  • 测试配置是否生效文章源自JAVA秀-https://www.javaxiu.com/65121.html

    修改passjava-member.properties的配置内容文章源自JAVA秀-https://www.javaxiu.com/65121.html

    Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

    passjava-member.properties文章源自JAVA秀-https://www.javaxiu.com/65121.html

    重启member服务文章源自JAVA秀-https://www.javaxiu.com/65121.html

    访问方法:/member/sample/test-local-config文章源自JAVA秀-https://www.javaxiu.com/65121.html

    执行结果:文章源自JAVA秀-https://www.javaxiu.com/65121.html

    {    "msg": "success",    "code": 0,    "nickname": "\"悟空member\"",    "age": 30}

    说明获取的是passjava-member命名空间的配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.8 分组

如果我们有多套环境,比如开发环境,测试环境,生产环境,每一套环境的配置参数不一样,那配置中心该如何配置呢?文章源自JAVA秀-https://www.javaxiu.com/65121.html

我们可以使用配置中心的分组功能。每一套环境都是一套分组。文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 首先创建一套dev环境配置项,然后克隆配置到test和prod环境文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

dev环境文章源自JAVA秀-https://www.javaxiu.com/65121.html

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

dev、test、prod分组文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • bootstrap.properties配置当前使用的分组:prod文章源自JAVA秀-https://www.javaxiu.com/65121.html

spring.cloud.nacos.config.group=prod
  • 测试获取生产环境配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

    {    "msg": "success",    "code": 0,    "nickname": "\"悟空-prod\"",    "age": 10}

    可以看到获取到的是prod分组的配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9 多配置集

我们可以将application.yml文件中的datasource、mybatis-plus等配置进行拆解,放到配置中心。group可以创建3套,dev/test/prod。文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.1 配置中心新建datasource.yml 配置

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

datasource.yml 配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.2 配置中心新建mybatis.yml 配置

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

mybatis.yml配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.3 配置中心新建more.yml 配置

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

more.yml配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.4 克隆dev环境配置到test和prod环境

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

mark文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.5 bootstrap.properties增加nacos配置,application.yml注释配置

spring.application.name=passjava-memberspring.cloud.nacos.config.server-addr=127.0.0.1:8848spring.cloud.nacos.config.namespace=passjava-memberspring.cloud.nacos.config.group=prodspring.cloud.nacos.config.extension-configs[0].data-id=datasource.ymlspring.cloud.nacos.config.extension-configs[0].group=devspring.cloud.nacos.config.extension-configs[0].refresh=truespring.cloud.nacos.config.extension-configs[1].data-id=mybatis.ymlspring.cloud.nacos.config.extension-configs[1].group=devspring.cloud.nacos.config.extension-configs[1].refresh=truespring.cloud.nacos.config.extension-configs[2].data-id=more.ymlspring.cloud.nacos.config.extension-configs[2].group=devspring.cloud.nacos.config.extension-configs[2].refresh=true

2.9.6 测试配置是否生效

  • 测试passjava-member.properties和more.yml配置是否生效文章源自JAVA秀-https://www.javaxiu.com/65121.html

请求url:http://localhost:10000/member/sample/test-local-config文章源自JAVA秀-https://www.javaxiu.com/65121.html

返回配置的nick和age,且端口是10000,且member服务注册到注册中心文章源自JAVA秀-https://www.javaxiu.com/65121.html

{    "msg": "success",    "code": 0,    "nickname": "\"悟空-prod1\"",    "age": 22}
  • 测试datasource.yml和mybatis.yml配置是否生效文章源自JAVA秀-https://www.javaxiu.com/65121.html

请求url:http://localhost:10000/member/member/list文章源自JAVA秀-https://www.javaxiu.com/65121.html

返回数据库查询结果文章源自JAVA秀-https://www.javaxiu.com/65121.html

{    "msg": "success",    "code": 0,    "page": {        "totalCount": 0,        "pageSize": 10,        "totalPage": 0,        "currPage": 1,        "list": []j    }}

说明以上配置都生效了。文章源自JAVA秀-https://www.javaxiu.com/65121.html

更多配置项

Nacos 手摸手教程文章源自JAVA秀-https://www.javaxiu.com/65121.html

2.9.10 使用Nacos总结

  • 1.引入Nacos依赖文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 2.配置Nacos数据源文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 3.配置中心配置数据集DataId和配置内容文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 4.开启动态刷新配置@RefreshScope文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 5.获取配置项的值@value文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 6.优先使用配置中心的配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 7.使用命名空间namespace来创建各服务的配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 8.使用分组group来区分不同环境文章源自JAVA秀-https://www.javaxiu.com/65121.html

  • 9.使用多配置集extension-configs区分不同类型的配置文章源自JAVA秀-https://www.javaxiu.com/65121.html

文章源自JAVA秀-https://www.javaxiu.com/65121.html
继续阅读
速蛙云 - 极致体验,强烈推荐!!!购买套餐就免费送各大视频网站会员!快速稳定、独家福利社、流媒体稳定解锁!速度快,全球上网、视频、游戏加速、独立IP均支持!基础套餐性价比很高!这里不多说,我一直正在使用,推荐购买:https://www.javaxiu.com/59919.html
weinxin
资源分享QQ群
本站是JAVA秀团队的技术分享社区, 会经常分享资源和教程; 分享的时代, 请别再沉默!
沙海
  • 版权声明:本站是JAVA秀团队的技术分享社区,我们会经常分享资源和教程。
  • 转载请注明:Nacos 手摸手教程 - JAVA秀 ☜(ˆ▽ˆ)
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定