springboot整合nacos的入門Demo及Nacos安裝部署
Nacos介紹
Nacos /nɑ:k??s/ 是 Dynamic Naming and Configuration Service的首字母簡稱,一個更易于構(gòu)建云原生應(yīng)用的動態(tài)服務(wù)發(fā)現(xiàn)、配置管理和服務(wù)管理平臺。
Nacos 致力于幫助您發(fā)現(xiàn)、配置和管理微服務(wù)。Nacos 提供了一組簡單易用的特性集,幫助您快速實現(xiàn)動態(tài)服務(wù)發(fā)現(xiàn)、服務(wù)配置、服務(wù)元數(shù)據(jù)及流量管理。
Nacos 幫助您更敏捷和容易地構(gòu)建、交付和管理微服務(wù)平臺。 Nacos 是構(gòu)建以“服務(wù)”為中心的現(xiàn)代應(yīng)用架構(gòu) (例如微服務(wù)范式、云原生范式) 的服務(wù)基礎(chǔ)設(shè)施。
官方文檔
https://nacos.io/zh-cn/docs/what-is-nacos.html
Nacos安裝部署
環(huán)境依賴:
- JDK1.8+
下載地址官網(wǎng)地址:
https://github.com/alibaba/nacos/releases百度網(wǎng)盤地址:
鏈接: https://pan.baidu.com/s/1Qr8Y1K92PLs1x54BR1X27A 提取碼: webx
Nacos的安裝部署非常簡單,如果只是作為測試學習,那么只需要將下載下來的Nacos進行解壓,然后到bin目錄,根據(jù)當前系統(tǒng)運行對應(yīng)的startup.cmd即可。
注:如果nacos的版本在2.2.0+以上的版本時,必須執(zhí)行此變更,否則無法啟動。
修改conf目錄下的application.properties文件。
設(shè)置其中的nacos.core.auth.plugin.nacos.token.secret.key值,詳情可查看鑒權(quán)-自定義密鑰.
Nacos支持三種部署模式
單機模式 - 用于測試和單機試用。
集群模式 - 用于生產(chǎn)環(huán)境,確保高可用。
多集群模式 - 用于多數(shù)據(jù)中心場景。
將下載下來的nacos包進行解壓,如果是window系統(tǒng),打開bin文件夾,雙擊運行startup.cmd即可,linux也是一樣,執(zhí)行 sh startup.sh 命令。
默認運行的是集群模式,如果不想使用集群,只想用單機模式,那么需要再運行的時候添加如下命令.
window:
startup.cmd -m standalone
linux:
startup.sh -m standalone
如果不想每次運行添加上述命令,那么可以修改startup.cmd或sh startup.sh腳本,修改為set MODE="standalone",示例圖如下:
配置完畢之后,執(zhí)行啟動腳本,啟動Nacos,默認地址為http://localhost:8848/nacos,賬號和密碼為nacos/nacos,如果不想用這個,可以在登錄之后的權(quán)限控制->用戶列表菜單中進行修改。
示例圖如下:
Springboot整合Nacos示例
環(huán)境依賴
- JDK1.8+
- Springboot2.x
- nacos2.x
官方的版本對應(yīng)建議配置:
版本 0.2.x.RELEASE 對應(yīng)的是 Spring Boot 2.x 版本,版本 0.1.x.RELEASE 對應(yīng)的是 Spring Boot 1.x 版本。
但是為了防止版本問題,強烈建議Springboot的版本和nacos的版本完全一致。
maven倉庫配置如下;
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.1.RELEASE</version> <relativePath/> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- Spring Boot Test 依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2.2.1.RELEASE</version> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.2.1.RELEASE</version> </dependency> <!--日志 --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${slf4j}</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>${logback}</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>${logback}</version> </dependency> </dependencies>
注:如果Springboot是2.4以上的版本,maven倉庫需要額外增加如下依賴:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bootstrap</artifactId> </dependency>
一個簡單的示例
首先創(chuàng)建一個配置文件,配置文件用bootstrap.properties,配置信息如下:
spring.banner.charset=UTF-8 server.tomcat.uri-encoding=UTF-8 spring.http.encoding.charset=UTF-8 spring.http.encoding.enabled=true spring.http.encoding.force=true spring.messages.encoding=UTF-8 server.port=8299 spring.application.name=springboot-nacos spring.profiles.active=dev # nacos配置 ## Nacos服務(wù)自動注冊 nacos.discovery.autoRegister=true ## Nacos服務(wù)注冊中心地址 spring.cloud.nacos.discovery.server-addr= http://127.0.0.1:8848 ## Nacos服務(wù)配置中心地址 spring.cloud.nacos.config.server-addr= http://127.0.0.1:8848
然后再來創(chuàng)建一個基本的啟動類
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; /** * @Author pancm * @Description springboot集成nacos配置中心 * @Date 2024/1/26 * @Param * @return **/ @SpringBootApplication @EnableDiscoveryClient public class App { private static final Logger logger = LoggerFactory.getLogger(App.class); public static void main( String[] args ) { // 啟動嵌入式的 Tomcat 并初始化 Spring 環(huán)境及其各 Spring 組件 SpringApplication.run(App.class, args); logger.info("程序啟動成功!"); } }
這里我們還需要對配置是否生效進行測試,這里就創(chuàng)建一個Controller,然后調(diào)用接口的時候返回配置信息。@RefreshScope注解是可以進行動態(tài)刷新。
import org.springframework.beans.factory.annotation.Value; import org.springframework.cloud.context.config.annotation.RefreshScope; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import static org.springframework.web.bind.annotation.RequestMethod.GET; /** * @Author pancm * @Description 官方示例文檔 * @Date 2024/1/26 * @Param * @return **/ @RestController @RequestMapping("config") @RefreshScope public class ConfigController { @Value("${pcm.name:pcm-1001}") private String name; @RequestMapping(value = "/getName", method = GET) public String getName() { return name; } }
注:這里為了防止啟動失敗,添加配置的時候設(shè)置一個默認值。
然后運行App,啟動成功,日志信息如下:
首先我們調(diào)用接口來查看當前的配置信息,輸入http://localhost:8299/config/getName,返回示例圖如下,可以看到是可以獲取默認的配置。
然后我們在Nacos的頁面上面添加一個pcm.name的配置,并且更改配置的值,這里我們更改為pcm-2001,然后點擊發(fā)布。
這里需要注意一下DataId的名稱命名規(guī)則,默認的情況下dataId=prefix.file-extension
,其中profix默認為${spring.application.name}
,file-extension
默認為properties。
如果指定了spring.profile.active
,那么就會變成dataId=prefix-spring.profile.active.file-extension
。
比如上述的項目名稱為springboot-nacos
,配置文件的后綴是properties,那么DataId就是springboot-nacos.properties
,指定了spring.profile.active=dev
,那么DataId就是springboot-nacos-dev.properties
。
但是我指定了spring.profile.active=dev
,為什么DataId是springboot-nacos.properties
也可以呢?因為這里還涉及到一個優(yōu)先級的問題。
DataId有三個配置規(guī)則
- dataId =
prefix
- dataId =
prefix.file-extension
- dataId =
prefix-spring.profile.active.file-extension
他們的優(yōu)先級是按照匹配的精準度來進行了,也就是如果配置多個dataId的話,那么他會匹配最相近的,也就是匹配優(yōu)先級是3>2>1,這里我們也可以通過啟動中的日志進行查看。
發(fā)布成功之后我們可以看到日志也進行了刷新。
然后我們再進行訪問http://localhost:8299/config/getName。通過下面的示例圖我們可以看到配置已經(jīng)刷新為我們設(shè)置的最新配置了。
Nacos配置管理
上述示例中,我們已經(jīng)完成了一個簡單的獲取Nacos中的配置示例,并且可以實現(xiàn)配置刷新。但是如果我們有多個服務(wù)使用的話,那么我們需要對配置進行區(qū)分,不建議都是用默認的public空間,因此我們還需要創(chuàng)建新的命名空間,如果還有分組要求(一般就是環(huán)境區(qū)分,dev、test、prod),那么我們還可以再進行創(chuàng)建配置時指定好group。
在nacos的命名空間菜單中,我們創(chuàng)建一個新的命名空間,其中命名空間ID這個保證唯一就行,默認可以不填寫。
創(chuàng)建成功之后,我們在來創(chuàng)建一個新的配置并且指定分組為dev,方便我們管理。此時里面的配置內(nèi)容為pcm.name =pcm-dev
。
創(chuàng)建完成之后,我們在Springboot的項目配置文件中新增如下配置:
## nacos命名空間id spring.cloud.nacos.config.namespace= pcm-namespace--id ## 對應(yīng)的分組名稱 spring.cloud.nacos.config.group= dev ## 配置文件后綴名,也可以不配置,默認為properties spring.cloud.nacos.config.fileExtension= properties
重新啟動項目,查看日子,我們可以看到已經(jīng)配置成功了。
然后我們在重新啟動項目,http://localhost:8299/config/getName 通過下面的示例圖我們可以看到配置已經(jīng)是設(shè)置的命名空間配置了。
多配置文件
在使用Nacos中,有時配置太多,不想放在一個配置文件中,此時就可以使用多個配置文件來進行區(qū)分管理。
在bootstrap.properties配置文件中新增如下配置,如果后續(xù)還有新的配置,參考下列配置,遞增extension-configs[0]的數(shù)值即可,比如在新增一個配置文件,那么就是extension-configs[1] = xxx.properties 這樣配置就可以了。
# 新增額外配置 ##額外的第一個配置文件的dataId spring.cloud.nacos.config.extension-configs[0].data-id=pcm-dev.properties ##額外的第一個配置文件的分組 spring.cloud.nacos.config.extension-configs[0].group=dev
在nacos中新增改配置文件,然后這里添加一個新的配置pcm.age=28
.
然后再ConfigController代碼中新增如下接口,添加完成之后重啟項目。
@Value("${pcm.age:18}") private String age; @RequestMapping(value = "/getAge", method = GET) public String getAge() { return age; }
訪問http://localhost:8299/config/getAge。通過下面的示例圖我們可以看到配置已經(jīng)生生效了。
其他
關(guān)于SpringBoot整合nacos的demo簡單講解的文章就講解到這里了,如有不妥,歡迎指正!
到此這篇關(guān)于springboot整合nacos的入門Demo及Nacos安裝部署的文章就介紹到這了,更多相關(guān)springboot整合nacos內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于RowBounds分頁原理、RowBounds的坑記錄
這篇文章主要介紹了關(guān)于RowBounds分頁原理、RowBounds的坑記錄,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之貪心算法
我們可能在好多地方都會聽到貪心算法這一概念,并且它的算法思想也比較簡單就是說算法只保證局部最優(yōu),進而達到全局最優(yōu)。但我們實際編程的過程中用的并不是很多,究其原因可能是貪心算法使用的條件比較苛刻,所要解決的問題必須滿足貪心選擇性質(zhì)2022-02-02