百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

来了,来了!Nacos 2.0的Spring Boot Starter终于来了

liuian 2025-01-15 15:15 53 浏览

随着Nacos2.0成熟稳定,Nacos-spring-boot发布0.1.10、0.2.10两个核心版本,全面支持了Nacos2.0,同时支持自动识别配置类型注入能力,修复了高并发场景下数据一致性问题。

Nacos-spring-boot老用户,将相关maven依赖进行如下替换,即可快速升级。

<dependency> 
  <groupId>com.alibaba.boot</groupId> 
   <artifactId>nacos-config-spring-boot-starter</artifactId> 
   <version>0.2.10</version> 
</dependency> 

本文将系统介绍新版本增强能力,并且以一次生产环境的配置管理项目构建过程为例,详细描述新版本Nacos Spring Boot0.2.10版本的部署,帮助Spring Boot老玩家快速上岸Nacos2.0,感受长连接带来的10倍性能提升。

Nacos-spring-boot新版本特性

新发布的0.1.10版本和0.2.10版本主要feature增强包括以下几个部分:

全面兼容Nacos2体系,向长连接时代演进

Nacos1体系中,配置中心的订阅、实时推送功能主要通过长轮训进行。尽管长轮训是HTTP短连接体系中被采用较多的动态刷新解决方案,但也不可避免地存在时延过高等缺陷;在生产实践中暴露了一定问题,如下面这两个链接所示:

  • https://github.com/alibaba/nacos/issues/6345
  • https://github.com/alibaba/nacos/issues/2674

Nacos2体系将整个配置中心的订阅、推送功能重构成为了基于gRPC的长连接方案,保证了配置刷新实时推送;迄今为止,已经历了大量的生产环境考验。

自动识别配置的文件类型

在使用Nacos-spring-boot新版本之后,即使用户对配置类型未设置的情况下,nacos-spring-boot也会自动识别该配置的文件类型(json/yaml/properties)并给定默认值。该机制极大降低了因为文件类型不匹配,业务侧出现配置处理错误的风险。下图为新版本Nacos-spring-boot项目在一次配置文件刷新过程中的工作机制。

@NacosValue注解全面支持Spel表达式

Spel表达式全称为“Spring Expression Language”,是Spring自带的一种动态字符串构建方式表达式)。用户可以方便地使用Spel表达式来定义NacosValue,与Spring功能完美整合,减少SpringBoot玩家们的工作量。

修复了高并发场景下的一致性问题

阿里云内部同学在使用Nacos-spring-boot项目进行大规模压测的过程中,出现了一些配置读取错误:在大流量频繁修改某些dataId的配置的过程中,客户端可能会拉取到旧版本的配置数据,导致客户端配置数据反复。Nacos-spring-boot新版本通过增加智能锁、升级Nacos-spring依赖等方式,对于潜在的线程安全风险进行了修复。

生产演示-客户端部署

Springboot老玩家可以通过下面方式升级到Nacos-spring-boot新版本。

在 Maven 项目的 pom.xml 文件中增加(或升级)以下依赖来获取 Starter

<dependency> 
    <groupId>com.alibaba.boot</groupId> 
    <artifactId>nacos-config-spring-boot-starter</artifactId> 
    <version>0.2.10</version> 
</dependency> 

注: 使用时请根据自定义构建的Spring Boot版本选择相应的nacos-config-spring-boot-starter版本:nacos-config-spring-boot-starter 版本 0.2.10 对应 Spring Boot 2.x 版本,版本 0.1.10 对应 Spring Boot 1.x 版本。

在 application.properties 文件中配置连接信息

nacos.config.server-addr=${nacos_server_address}:8848 

注:${nacos_server_address}为占位符,表示Nacos server的地址,后文将给出如何获取其详细地址信息的方案。

使用 @NacosPropertySource 加载 dataId 为 example 的配置源,并开启自动更新

@SpringBootApplication 
@NacosPropertySource(dataId = "com.alibaba.nacos.example.properties", autoRefreshed = true) 
public class NacosConfigApplication { 
     public static void main(String[] args) { 
         SpringApplication.run(NacosConfigApplication.class, args); 
     }  
} 

使用 @NacosValue 注解设置属性值。

@Controller  
@RequestMapping("config")  
public class ConfigController {  
    @NacosValue(value = "${connectTimeoutInMills:5000}", autoRefreshed = true)  
    private int connectTimeoutInMills;   
    @RequestMapping(value = "/get", method = GET)  
    @ResponseBody  
    public int get() {  
        return connectTimeoutInMills; 
    }  
} 

生产演示-服务端部署

Nacos官方为SpringBoot玩家提供了两种服务端的部署方式:自建开源Nacos和MSE Nacos专业版。

自建开源Nacos

用户如果选择开源Nacos,可以进行自主部署、运维、生产环境调优;另外,由于开源Nacos协议为Apache2.0协议,用户甚至可以进行自定义功能的开发。开源Nacos的安装步骤可参考https://github.com/alibaba/nacos,支持环境包括Windows、MacBook、Linux等各种平台,可以方便地进行单机或集群启动。

MSE Nacos专业版

MSE Nacos则致力于提供高可用的一站式解决方案,相对于基础版和开源版本进行了大量升级:

  • 自动化升级流程,无需复杂运维部署,即可完成基础版至专业版的平滑升级。
  • 提供企业级99.95%高可用保障。
  • 支持长链接,性能相对于基础版提升10倍。
  • 更完善的配置加解密体系,无需担心敏感配置信息丢失风险。
  • 更完善的鉴权体系,全面引入阿里云RAM主子账号体系权限控制。

使用MSE Nacos专业版作为服务端,详细步骤可分为如下几步。

1、首先访问MSE官网,https://cn.aliyun.com/product/aliware/mse?spm=nacos-website.topbar.0.0.0,登陆。

2、点击"立即购买"、"创建实例"。

3、选择“专业版”,并根据需要进行其他相应设置。

并点击立即购买。

4、等待3分钟,即可在控制台看到刚刚创建的Nacos集群。

5、将相应内网或公网地址复制,并填入上文所述${nacos_server_address}中。(如希望使用内网访问,则可直接复制内网地址;如希望使用公网访问,则需要点击进入并将访问端添加进公网白名单)。

6、点击进入相应实例的控制台,点击“配置列表”、“创建配置”。

7、创建和客户端匹配的配置信息,注意下图中红框标出的几个项目(其中数据加密根据需要选择),最后点击“发布”。

结果验证

在本地启动客户端项目,并运行以下命令:

curl localhost:8080/config/get 

若返回以下信息,则说明 SDK 可正常使用。

  1. 3000

在MSE控制台将实例配置 com.alibaba.nacos.example.properties更改为以下内容并发布。

connectTimeoutInMills=6000 

若Console打印出更新的配置内容 ,则说明SDK的配置自动更新功能正常;工程正式跨入高性能配置中心时代。

相关推荐

手机临时文件夹在哪个位置(手机临时文件夹在哪个位置找)

1.手机文件临时文件是指在手机使用过程中产生的临时文件。2.手机应用程序在运行时需要产生一些临时文件,如缓存文件、日志文件、临时下载文件等,这些文件可以提高应用程序的运行效率和用户体验。但是,这些...

安卓10系统下载(安卓10 下载)

方法及步骤:  其实使用安卓车机下载歌曲的方法十分的简单,具体操作步骤和安卓手机一模一样。  首先我们需要在车机的应用商店上,下载一个音乐播放器,例如网易云音乐或者QQ音乐等。  下载完成后点击进入...

华硕人工客服24小时吗(华硕售后人工客服)

华硕服务中心广东省惠州市惠东县城平深路(创富斜对面)惠东同心电脑城1L11(1.3km)笔记本电脑,平板电脑华硕服务中心广东省惠州市惠东县平山镇同心电脑城1F26(1.3km)笔记本电脑,平...

电脑音量小喇叭不见了(电脑声音喇叭图标不见了怎么办)

如果您电脑上的小喇叭(扬声器)不见了,可以尝试以下方法找回:1.检查设备管理器:在Windows下,右键点击“我的电脑”(或此电脑)->点击“属性”->点击“设备管理器”,查看“声音、视...

腾达路由器手机设置教程(腾达路由器手机设置教程视频)

用手机设置腾达路由器的方法如下:1在手机上打开浏览器,输入路由器背面的管理IP和用户及对应的密码2一般第一次打开,默认会跳出设置向导,准备好宽带用户名和密码,3按向导提示输入相应内容4在无线设置的安全...

自配电脑配置推荐(自配电脑配置推荐百度)

首先,像这类软件最低要求不高。最高没上限。纯粹看你的工程量大小。CPU有双核,内存有4G,就可以运行。但是实际体验肯定比较差,卡是肯德。渲染时间也会超长,一个小作品渲染几小时是正常的。稍微大点的工程也...

2025年平板性价比排行(2020年值得买的平板)

推荐台电P30S好。 基本配置:10.1英寸IPS广视角屏幕,1280*800分辨率,16:10的黄金显示比例,K9高压独立功放,支持3.5mm耳麦接口,联发科MT8183八核处理器,4GB...

2020显卡天梯图10月(2020显卡天梯图极速空间)

排行球队名称积分已赛胜平负进球失球净胜球  1?诺维奇城974629107753639 2?沃特福德91462710...

路由器加密防蹭网(路由器加密防蹭网吗)
  • 路由器加密防蹭网(路由器加密防蹭网吗)
  • 路由器加密防蹭网(路由器加密防蹭网吗)
  • 路由器加密防蹭网(路由器加密防蹭网吗)
  • 路由器加密防蹭网(路由器加密防蹭网吗)
笔记本电脑无线网络连接(笔记本电脑无线网络连接不上怎么办)
笔记本电脑无线网络连接(笔记本电脑无线网络连接不上怎么办)

一、笔记本电脑怎么连接wifi---win7系统笔记本连接wifi1、要先创建无线网络连接,将鼠标移到Win7的开始菜单,然后点击“控制面板”。2、然后点击“网络和Internet”。3、再打开“网络和共享中心”,这是Win7系统必有的功...

2025-12-22 05:55 liuian

wind数据库(wind数据库官网)

先购买wind数据库,安装好wind取得使用权后,按照wind所给提示,输入账户和密码可使用wind数据库。Wind资讯金融终端是一个集实时行情、资料查询、数据浏览、研究分析、新闻资讯为一体的金融数据...

如何关闭360家庭防火墙(如果关闭360家庭防火墙)

关闭方法如下:1.打开手机360主界面之后,点击“安全防护中心”。2.点击第三列“入口防护”下方的“查看状态”按钮。3.在列出的功能项中找到“局域网防护”,直接点击后面的“关闭”按钮,关闭所有的“局域...

笔记本电脑型号配置怎么看(怎么查自己电脑的型号)

查电脑的配置和型号方法:方法一:1、右键单击“此电脑”,点击属性2、这里可以看到操作系统,CPU等大致信息3、点击设备管理器4、这里可以查看具体硬件的详细信方法二:1、首先打开电脑上的“控制面板”2、...

pscs6序列号是什么

AdobePhotoshopCS6就二个版本(测试版和正式版)1、AdobePhotoshopCS6是AdobePhotoshop的第13代,是一个较为重大的版本更新。2、Photoshop在前几...

win7桌面图片怎么设置(win7如何设置桌面图片)

1、首先用鼠标右键单击桌面的空白处。然后在弹出的菜单上选择“个性化”选项。这样就弹出了的个性化窗口上能显示看到“桌面背景”按钮。点击它即可。2、继续打开了选择“桌面背景”选项,然后在上面选择你想要设置...