写点什么

阿里 P8 大佬总结的 Nacos 入门笔记,从安装到进阶小白也能轻松学会

  • 2022-11-25
    湖南
  • 本文字数:3749 字

    阅读完需:约 12 分钟

前言

都说程序员工资高、待遇好, 2022 金九银十到了,你的小目标是 30K、40K,还是 16 薪的 20K?作为一名 Java 开发工程师,当能力可以满足公司业务需求时,拿到超预期的 Offer 并不算难。然而,提升 Java 核心能力最快、最有效,短期内升职加薪的方法,到底是什么?


首先,你需要跳出日常工作,接触更有深度、更前沿的顶级项目。一个简单的逻辑:大厂之所以能够给到高于行业水准的薪资,正是因为即使是普通开发人员,也要应对很多复杂的场景。这些复杂场景和项目,就像“墙外的世界”,没有看过,没有接触过,你就无法进行体系化的学习和建立认知,技术壁垒自然就出现了。


所以,如果你期望通过个人努力,实现收入增长和职位晋升,那最好的方式,一定是多学多看多做。


Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。


Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。


Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。



在这个介绍中,可以看出 Nacos 至少有三个核心功能:


1. 动态服务发现


2. 配置管理


3. 服务管理


后续会分别来介绍这三个功能是怎么回事

下载和解压

教程制作时,Nacos 的最新发⾏版为 2.1.1 (Aug 8th, 2022)(本教程就是基于这个版本),官⽅当前推荐的稳定版本为 2.0.3。


查看最新Nacos发⾏版:https://github.com/alibaba/nacos/releases
复制代码


并且可以在此⽹⻚上下载安装包:



下载完了之后进⾏解压,解压之后的⽬录为:



1. bin⽬录下是启动和停⽌的脚本


2. conf⽬录下是 Nacos 的配置⽂件


3. target⽬录下是 Nacos 的 jar 包(启动脚本中其实就是运⾏的这个 jar 包,停⽌脚步中是直接 kill 到进程)

启动

解压完之后就可以启动 Nacos 了,Nacos⽀持单机和集群,默认是以集群模式启动,通过添加-mstandalone 就会以单机模式启动。

Linux/Unix/Mac

启动命令(standalone 代表着单机模式运⾏,⾮集群模式):


sh startup.sh -m standalone
复制代码


如果您使⽤的是 ubuntu 系统,或者运⾏脚本报错提示[[符号找不到,可尝试如下运⾏:


bash startup.sh -m standalone
复制代码

Windows

启动命令(standalone 代表着单机模式运⾏,⾮集群模式):


startup.cmd -m standalone
复制代码



可以发现,默认情况下 Nacos 占⽤了 8848 端⼝。


我们可以访问http://localhost:8848/nacos,来访问Nacos:
复制代码



默认的⽤户名和密码为:nacos/nacos



这个⽹⻚相当于 nacos 的管理台,有:


1. 配置管理


2. 服务管理


3. 权限控制


4. 命名空间


5. 集群管理

配置管理

配置,其实就是⼀个 key:value,⽐如



并且我们通常会把这些配置写在 application.properties 或 application.yml⽂件中,当时通过这种⽅式⼀定配置发⽣了改变就需要重启应⽤,并且通过这种⽅式配置的配置项仅限于当前应⽤,⽽不能做到多个应⽤共享。


那么 nacos 的配置管理功能就是来解决这些问题的,我们可以直接通过 nacos 管理台来新增配置,并且这些配置能够被多个应⽤给使⽤到。

新建配置

新建配置时可以指定:


1. Data ID:相当于⼀个配置⽂件,⽐如相当于 application.properties,或者 application-dev.properties,不过要注意的是,我们在某个项⽬中使⽤application.properties⽂件中,那个 application 表示的就是当前应⽤,那我们在 nacos 进⾏配置时,就要尽可能的取⼀些有含义的 DataID,⽐如 user.properties(表示⽤户应⽤的配置),order.properties(表示订单应⽤的配置),common.properties(表示多个应⽤共享的配置)。


2. Group:在 nacos 中,⼀个 Data ID,也就是⼀个或多个配置⽂件可以归类到同⼀个 Group 中,Group 的作⽤就是⽤来区分 Data ID 相同的情况,不同的应⽤或中间件使⽤了相同的 Data ID 时就可以通过 Group 来进⾏区分,默认为 DEFAULT_GROUP


3. 配置内容:写具体的配置项,可以⽤properties 的格式,也可以⽤yaml 的格式


⽐如:


拉取配置

在 nacos 中新建完配置后,那作为⼀个 SpringBoot 应⽤我们如何来获取配置呢?

Java SDK

⾸先,我们可以直接使⽤Nacos 提供的 Java SDK 来获取配置。


⾸先在项⽬中,添加如下依赖:


<dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-client</artifactId><version>2.1.1</version></dependency>
复制代码


然后可以使⽤如下代码来获取 nacos 中的配置:


try {String serverAddr = "localhost:8848";String dataId = "user.properties";String group = "DEFAULT_GROUP";Properties properties = new Properties();properties.put("serverAddr", serverAddr);ConfigService configService = NacosFactory.createConfigService(properties);String content = configService.getConfig(dataId, group, 5000);System.out.println(content); } catch (NacosException e) {// TODO Auto-generated catch blocke.printStackTrace(); }
复制代码


1. serverAddr:nacos 的地址


2. dataId:想要获取的配置⽂件的名字


3. group:分组


在 Java SDK 中,除开有获取配置的 API,同时也提供了新增、删除、监听配置的 API。


我们可以通过如下代码来监听配置的变化:


try {String serverAddr = "localhost:8848";String dataId = "user.properties";String group = "DEFAULT_GROUP";Properties properties = new Properties();properties.put("serverAddr", serverAddr);ConfigService configService = NacosFactory.createConfigService(properties);String content = configService.getConfig(dataId, group, 5000);System.out.println(content);configService.addListener(dataId, group, new Listener() {public void receiveConfigInfo(String configInfo) {System.out.println("recieve1:" + configInfo); }public Executor getExecutor() {return null; } });// 测试让主线程不退出,因为订阅配置是守护线程,主线程退出守护线程就会退出。 正式代 码中⽆需下⾯代码while (true) {try {Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } } catch (NacosException e) {// TODO Auto-generated catch blocke.printStackTrace(); }
复制代码


剩余 API,⼤家可以直接参考官⽹: https://nacos.io/zh-cn/docs/sdk.html


Spring 在真正开发时,我们不太会通过 Java SDK 的⽅式来拉取 nacos 中的配置,那 Nacos 有没有针对 Spring 提供⼀些⽐较好⽤的注解或 API 呢?


当然是有的


增加⼀下依赖(不再需要 nacos-client 依赖了)


<dependency> <groupId>com.alibaba.nacos</groupId> <artifactId>nacos-spring-context</artifactId> <version>1.1.1</version> </dependency>
复制代码


我们可以按以下⽅式来配置 Spring 容器:


@Configuration@EnableNacosConfig(globalProperties = @NacosProperties(serverAddr = "127.0.0.1:8848")) @NacosPropertySource(dataId = "user.properties", autoRefreshed = true) @ComponentScan("com.zhouyu")public class AppConfig { }
复制代码


很明显,通过 @EnableNacosConfig 注解定义了 nacos 的地址,通过 @NacosPropertySource 表示想要拉取的 dataId,并且设置⾃动刷新(也就是配置发⽣了改变则会⾃动⽣效)。


那如何使⽤某⼀个具体的配置项呢:


@Componentpublic class UserService { @NacosValue("${spring.datasource.username}") private String username; public void test(){ System.out.println(username); } }
复制代码


可以通过 @NacosValue 来使⽤某⼀具体的配置项,那 @Value⾏不⾏呢?也是可以的。


之所以可以,原因是 @EnableNacosConfig 注解会负责把指定的 dataId 的配置项拉取到应⽤,并封装为 PropertySource 对象添加到 Environment 对象中,所以 @Value 也能读取到相应的配置项。

SpringBoot

如果我们使⽤SpringBoot,那则可以⽐Spring 更加简单。


首先引入依赖:


<dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-config-spring-boot-starter</artifactId> <version>0.2.12</version> </dependency>
复制代码


然后在 application.properties 中配置 nacos 的地址:


nacos.config.server-addr=127.0.0.1:8848
复制代码


然后:


@SpringBootApplication@NacosPropertySource(dataId = "user.properties", autoRefreshed = true)public class UserApplication { public static void main(String[] args) { ConfigurableApplicationContext applicationContext = SpringApplication.run(UserApplication.class, args); UserService userService = applicationContext.getBean(UserService.class); userService.test(); } }
复制代码


依旧使⽤@NacosPropertySource 来指定要拉取的配置 dataId 即可,就可以使⽤@Value 或 @NacosValue 来获取某个具体的配置项了。


那有同学可能会想到,我们可不可以直接在 application.properties⽂件中来配置 dataid 呢?确实可以:


nacos.config.server-addr=127.0.0.1:8848nacos.config.data-id=user.propertiesnacos.config.bootstrap.enable=true
复制代码


不过要注意,⼀定得把 nacos.config.bootstrap.enable 设置为 true,不然是不⾏的。

SpringCloud

如果我们是⽤SpringCloud,那将⽐SpringBoot 更加简单。

总结


需要文章中配套资料的朋友可以——点击传送门

用户头像

还未添加个人签名 2022-09-20 加入

还未添加个人简介

评论

发布
暂无评论
阿里P8大佬总结的Nacos入门笔记,从安装到进阶小白也能轻松学会_Java_小二,上酒上酒_InfoQ写作社区