20 图|Nacos 手摸手教程
Nacos 作為服務注冊中心、配置中心,已經非常成熟了,業界的標桿,在講解 Nacos 的架構原理之前,我先給大家來一篇開胃菜:講解 Nacos 如何使用。
涉及到如下兩個話題:
用 Nacos 作為注冊中心。
用 Nacos 作為配置中心。
由于本篇是針對 Nacos 的使用和配置教程,可能會略顯枯燥,建議大家快速瀏覽一遍,然后收藏轉發下,以后說不定就會用上了~~
本篇主要內容如下:
Nacos 是阿里巴巴開源的一個更易于構建云原生應用的動態服務發現、配置管理和服務管理平臺。
一、Nacos 作為注冊中心
1.1 引入 Nacos 服務發現組件
passjava-common模塊的pom.xml文件引入Nacos 服務發現組件
<!--?nacos?discovery?服務發現組件--> <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>1.2 下載 Nacos Server 工具包并啟動
注意:我在 Windows 和 Mac 上都測試過,都可以正常使用。
下載Nacos Server 壓縮包
https://github.com/alibaba/nacos/releases
啟動 Server,進入解壓后文件夾或編譯打包好的文件夾,找到如下相對文件夾 nacos/bin,并對照操作系統實際情況之下如下命令。
Linux/Unix/Mac 操作系統,執行命令 sh startup.sh -m standalone
Windows 操作系統,執行命令 cmd startup.cmd
windows執行startupm.cmd遇到問題:
λ?startup.cmd??????????????????????????????????????????????????????Please?set?the?JAVA_HOME?variable?in?your?environment,?We?need?java(x64)!?jdk8?or?later?is?better!解決方案:
修改startup.cmd文件中的 %JAVA_HOME%
%JAVA_HOME%?替換為?C:\Program?Files\Java\jdk1.8.0_131啟動成功:
1.3 每個微服務都配置 Nacos Server 地址
配置Nacos Server 地址
在passjava-question、passjava-channel、passjava-content、passjava-member、passjava-study 應用的 /src/main/resources/application.yml配置文件中配置 Nacos Server 地址
spring:cloud:nacos:discovery:server-addr:?127.0.0.1:88481.4 添加注解
為每個服務使用 @EnableDiscoveryClient 注解開啟服務注冊與發現功能
@EnableDiscoveryClient @MapperScan("com.jackson0714.passjava.question.dao") @SpringBootApplication public?class?PassjavaQuestionApplication?{public?static?void?main(String[]?args)?{SpringApplication.run(PassjavaQuestionApplication.class,?args);}}1.5 配置微服務的名稱
spring:application:name:?passjava-question1.6 訪問nacos server后臺
登錄后臺
http://localhost:8848/nacos/index.html#/login
用戶名:nacos
密碼:nacos
查看已注冊的服務
passjava-channel?渠道微服務 passjava-member?用戶微服務 passjava-study?學習微服務 passjava-question?問題微服務 passjava-content?內容微服務
二、Nacos 作為配置中心
2.1 傳統配置方式
application.properties文件中定義兩個配置:
示例控制器中定義私有變量nickname和age,@value代表從配置中取值
示例控制器中定義方法:獲取nick和age的值
測試結果
總結:從配置文件中獲取配置。
這種方式的缺點是什么呢?如果要修改配置參數,則需要重新啟動服務。如果服務很多,則需要重啟所有服務,非常不方便。
有沒有什么辦法不停服務修改配置而且使其生效呢?
答案:有的,用Spring Cloud Alibaba的Nacos 組件就可以完成。
2.2 引入Nacos依賴
PassJava-Common項目的pom.xml文件引入Spring Cloud Alibaba Nacos Config依賴
<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 優先級高于其他配置文件)
配置 Nacos Config 元數據
2.4 Nacos后臺新增配置
Data ID: passjava-member.properties
Group: DEFAULT_GROUP
配置格式:
member.nick="悟空" member.age=10Nacos后臺新增配置2.5 開啟動態刷新配置功能
添加注解@RefreshScope開啟動態刷新配置功能
@RefreshScope @RestController @RequestMapping("member/sample") public?class?SampleController?{}可以從控制臺看到日志信息:
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@4f49b78bmember.age 更新了,通知了member服務,刷新了配置。對應的配置id為passjava-member.properties,分組為DEFAULT_GROUP。監聽器為com.alibaba.cloud.nacos.refresh.NacosContextRefresher
2.6 測試結果
訪問:http://localhost:10000/member/sample/test-local-config
結果:nickname和age和Nacos后臺配置一致
結論:只用在Nacos后臺改配置即可實時修改配置。
注意:Nacos的配置項優先級高于application.propertite里面的配置。
測試結果2.7 命名空間
我們現在有5個微服務,每個微服務用到的配置可能都不一樣,那不同微服務怎么樣獲取自己微服務的配置呢?
這里可以用到命名空間,我們針對每個微服務,都創建一個命名空間。
創建命名空間
創建命名空間
命名空間下創建配置
我們打開配置列表菜單,可以看到有五個命名空間。
命名空間下創建配置
選中passjava-channel命名空間,然后新增配置項,與之前新增配置的步驟一致,也可以通過克隆命名空間來克隆配置。
克隆配置修改指定的命名空間
bootstrap.properties配置命名空間
spring.cloud.nacos.config.namespace=passjava-member測試配置是否生效
修改passjava-member.properties的配置內容
passjava-member.properties重啟member服務
訪問方法:/member/sample/test-local-config
執行結果:
{"msg":?"success","code":?0,"nickname":?"\"悟空member\"","age":?30 }說明獲取的是passjava-member命名空間的配置
2.8 分組
如果我們有多套環境,比如開發環境,測試環境,生產環境,每一套環境的配置參數不一樣,那配置中心該如何配置呢?
我們可以使用配置中心的分組功能。每一套環境都是一套分組。
首先創建一套dev環境配置項,然后克隆配置到test和prod環境
bootstrap.properties配置當前使用的分組:prod
測試獲取生產環境配置
{"msg":?"success","code":?0,"nickname":?"\"悟空-prod\"","age":?10 }可以看到獲取到的是prod分組的配置
2.9 多配置集
我們可以將application.yml文件中的datasource、mybatis-plus等配置進行拆解,放到配置中心。group可以創建3套,dev/test/prod。
2.9.1 配置中心新建datasource.yml 配置
datasource.yml 配置2.9.2 配置中心新建mybatis.yml 配置
mybatis.yml配置2.9.3 配置中心新建more.yml 配置
more.yml配置2.9.4 克隆dev環境配置到test和prod環境
mark2.9.5 bootstrap.properties增加nacos配置,application.yml注釋配置
spring.application.name=passjava-member spring.cloud.nacos.config.server-addr=127.0.0.1:8848spring.cloud.nacos.config.namespace=passjava-member spring.cloud.nacos.config.group=prodspring.cloud.nacos.config.extension-configs[0].data-id=datasource.yml spring.cloud.nacos.config.extension-configs[0].group=dev spring.cloud.nacos.config.extension-configs[0].refresh=truespring.cloud.nacos.config.extension-configs[1].data-id=mybatis.yml spring.cloud.nacos.config.extension-configs[1].group=dev spring.cloud.nacos.config.extension-configs[1].refresh=truespring.cloud.nacos.config.extension-configs[2].data-id=more.yml spring.cloud.nacos.config.extension-configs[2].group=dev spring.cloud.nacos.config.extension-configs[2].refresh=true2.9.6 測試配置是否生效
測試passjava-member.properties和more.yml配置是否生效
請求url:http://localhost:10000/member/sample/test-local-config
返回配置的nick和age,且端口是10000,且member服務注冊到注冊中心
{"msg":?"success","code":?0,"nickname":?"\"悟空-prod1\"","age":?22 }測試datasource.yml和mybatis.yml配置是否生效
請求url:http://localhost:10000/member/member/list
返回數據庫查詢結果
{"msg":?"success","code":?0,"page":?{"totalCount":?0,"pageSize":?10,"totalPage":?0,"currPage":?1,"list":?[]j} }說明以上配置都生效了。
更多配置項
2.9.10 使用Nacos總結
1.引入Nacos依賴
2.配置Nacos數據源
3.配置中心配置數據集DataId和配置內容
4.開啟動態刷新配置@RefreshScope
5.獲取配置項的值@value
6.優先使用配置中心的配置
7.使用命名空間namespace來創建各服務的配置
8.使用分組group來區分不同環境
9.使用多配置集extension-configs區分不同類型的配置
SpringCloud Ribbon中的7種負載均衡策略!
SpringCloud Nacos + Ribbon 調用服務的 2 種方法!
Spring Cloud Alibaba Nacos 的 2 種健康檢查機制!
總結
以上是生活随笔為你收集整理的20 图|Nacos 手摸手教程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: c#中.clear()作用_清单 .C
- 下一篇: SpringBoot 使用注解实现消息广