1.Nacos簡介
1.1.為什么叫Nacos?
前四個字母分別為Naming和Configuration的前兩個字母,最后的s為service。
1.2.Nacos是什么?
nacos是第二代微服務SpringCloudAlibaba開源的一款注冊中心和分布式配置中心組件,其功能上為第一代微服務SpringCloud中Eureka和Config的結合體。簡而言之,Nacos可以實現分布式服務注冊與發現和分布式配置中心功能。
Nacos官方文檔: https://nacos.io/zh-cn/docs/what-is-nacos.html
1.3.Nacos能干嘛?
替代Eureka做服務注冊中心;
替代Config做服務配置中心;
Nacos 致力于幫助您發現、配置和管理微服務。Nacos 提供了一組簡單易用的特性集,幫助您快速實現動態服務發現、服務配置、服務元數據及流量管理。
Nacos 幫助您更敏捷和容易地構建、交付和管理微服務平臺。 Nacos 是構建以“服務”為中心的現代應用架構 (例如微服務范式、云原生范式) 的服務基礎設施。
1.4.去哪里下載Nacos以及文檔地址?
Nacos各個版本下載地址
https://github.com/alibaba/nacos/tags
Nacos GitHub地址
https://github.com/alibaba/Nacos
Nacos官網
https://nacos.io/zh-cn/
Nacos文檔地址
https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html
2.Nacos的關鍵特性
2.1.服務發現和服務健康監測
Nacos 支持基于 DNS 和基于 RPC 的服務發現。服務提供者使用 原生SDK、OpenAPI、或一個獨立的Agent TODO注冊 Service 后,服務消費者可以使用DNS TODO 或HTTP&API查找和發現服務。
Nacos 提供對服務的實時的健康檢查,阻止向不健康的主機或服務實例發送請求。Nacos 支持傳輸層 (PING 或 TCP)和應用層 (如 HTTP、MySQL、用戶自定義)的健康檢查。 對于復雜的云環境和網絡拓撲環境中(如 VPC、邊緣網絡等)服務的健康檢查,Nacos 提供了 agent 上報模式和服務端主動檢測2種健康檢查模式。Nacos 還提供了統一的健康檢查儀表盤,幫助您根據健康狀態管理服務的可用性及流量。
動態配置服務
動態配置服務可以讓您以中心化、外部化和動態化的方式管理所有環境的應用配置和服務配置。
動態配置消除了配置變更時重新部署應用和服務的需要,讓配置管理變得更加高效和敏捷。
配置中心化管理讓實現無狀態服務變得更簡單,讓服務按需彈性擴展變得更容易。
Nacos 提供了一個簡潔易用的UI (控制臺樣例 Demo) 幫助您管理所有的服務和應用的配置。Nacos 還提供包括配置版本跟蹤、金絲雀發布、一鍵回滾配置以及客戶端配置更新狀態跟蹤在內的一系列開箱即用的配置管理特性,幫助您更安全地在生產環境中管理配置變更和降低配置變更帶來的風險。
2.2.動態配置服務
動態配置服務可以讓您以中心化、外部化和動態化的方式管理所有環境的應用配置和服務配置。
動態配置消除了配置變更時重新部署應用和服務的需要,讓配置管理變得更加高效和敏捷。
配置中心化管理讓實現無狀態服務變得更簡單,讓服務按需彈性擴展變得更容易。
Nacos 提供了一個簡潔易用的UI (控制臺樣例 Demo) 幫助您管理所有的服務和應用的配置。Nacos 還提供包括配置版本跟蹤、金絲雀發布、一鍵回滾配置以及客戶端配置更新狀態跟蹤在內的一系列開箱即用的配置管理特性,幫助您更安全地在生產環境中管理配置變更和降低配置變更帶來的風險。
2.3.動態 DNS 服務
動態 DNS 服務支持權重路由,讓您更容易地實現中間層負載均衡、更靈活的路由策略、流量控制以及數據中心內網的簡單DNS解析服務。動態DNS服務還能讓您更容易地實現以 DNS 協議為基礎的服務發現,以幫助您消除耦合到廠商私有服務發現 API 上的風險。
Nacos 提供了一些簡單的 DNS APIs 幫助您管理服務的關聯域名和可用的 IP:PORT 列表
2.4.服務及其元數據管理
Nacos 能讓您從微服務平臺建設的視角管理數據中心的所有服務及元數據,包括管理服務的描述、生命周期、服務的靜態依賴分析、服務的健康狀態、服務的流量管理、路由及安全策略、服務的 SLA 以及最首要的 metrics 統計數據。
Nacos 全景圖如下圖:
如 Nacos 全景圖所示,Nacos 無縫支持一些主流的開源生態,例如
Spring Cloud
apache Dubbo and Dubbo Mesh
Kubernetes and CNCF。
使用 Nacos 簡化服務發現、配置管理、服務治理及管理的解決方案,讓微服務的發現、管理、共享、組合更加容易。
3.環境要求
3.1.預備環境準備
Nacos 依賴 Java 環境來運行。如果您是從代碼開始構建并運行Nacos,還需要為此配置 Maven環境,請確保是在以下版本環境中安裝使用:
64 bit OS,支持 Linux/Unix/Mac/Windows,推薦選用 Linux/Unix/Mac。
64 bit JDK 1.8+。
Maven 3.2.x+。
3.2.依賴
版本說明參考: https://github.com/alibaba/spring-cloud-alibaba/wiki/版本說明
spring-cloud-dependencies.version: Spring Cloud Hoxton.SR3
spring-cloud.version: 2.2.2.RELEASE
spring-cloud-alibaba-version: 2.2.0.RELEASE
spring-boot-version: 2.2.5.RELEASE
nacos-version: 1.1.4
4.版本依賴關系
5.nacos安裝
nacos的安裝和部署、啟動都可參照nacos官方文檔,這里我就以Windows環境為例,Windwos平臺下如果要使用nacos,需要先去下載nacos-server安裝包,下載完成后解壓,雙擊bin目錄下面的startup.cmd啟動即可。
nacos-server官網下載: https://github.com/alibaba/nacos/releases/
5.1.Windwos
nacos-server 1.2.1 Windows環境
注意: windwos環境下啟動nacos雙擊start.up即可。且windows環境默認是以單機模式啟動。
Windows環境啟動
cmd startup.cmd 或者雙擊 startup.cmd 文件
1.
5.2.Linux
nacos-server 1.2.1 Linux 環境
注意: linux環境默認是以集群機模式啟動的,所以如果使用的是linux,需要執行以下命令,表示單機模式啟動。
Linux/Unix/Mac環境啟動
sh startup.sh -m standalone
1.
啟動成功后如圖:
初始訪問地址: http://127.0.0.1:8848/nacos/index.html賬號密碼: nacos/nacos
6.環境搭建
以訂單(Order)調用商品(Product)為例,分別創建父工程springcloud-alibaba-nacos、子工程springcloud-alibaba-provider、springcloud-alibaba-consumer
6.1.搭建springcloud-alibaba-nacos
pom.xml
4.0.0
<groupId>com.bruce.springcloud-alibaba-nacos</groupId>
<artifactId>springcloud-alibaba-nacos</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules><module>springcloud-alibaba-provider</module><module>springcloud-alibaba-consumer</module>
</modules><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.2.5.RELEASE</version><type>pom</type><scope>import</scope></dependency><!--Spring Cloud --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Hoxton.SR3</version><type>pom</type><scope>import</scope></dependency><!-- Spring Cloud Alibaba--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.1.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
6.2.搭建springcloud-alibaba-provider服務提供者
pom.xml
springcloud-alibaba-nacos
com.bruce.springcloud-alibaba-nacos
1.0-SNAPSHOT
4.0.0
<artifactId>springcloud-alibaba-provider</artifactId><dependencies><!-- web組件 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><exclusions><!--排除tomcat依賴 --><exclusion><artifactId>spring-boot-starter-tomcat</artifactId><groupId>org.springframework.boot</groupId></exclusion></exclusions></dependency><!--undertow容器 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-undertow</artifactId></dependency><!--nacos服務注冊與發現 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!-- lombok插件 --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>
</dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>
application.yml
server:port: 8715
spring:cloud:nacos:discovery:server-addr: 127.0.0.1:8848enabled: trueapplication:name: nacos-product
啟動類AppProvider
package com.bruce;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** @BelongsProject: springcloud-alibaba-nacos* @BelongsPackage: com.bruce* @CreateTime: 2021-02-18 13:08* @Description: TODO*/@SpringBootApplication
public class AppProvider {public static void main(String[] args) {SpringApplication.run(AppProvider.class);}
}
啟動并測試
啟動并測試
查看注冊列表
6.3.搭建springcloud-alibaba-consumer服務消費者
pom.xml
springcloud-alibaba-nacos
com.bruce.springcloud-alibaba-nacos
1.0-SNAPSHOT
4.0.0
<artifactId>springcloud-alibaba-consumer</artifactId><dependencies><!--nacos服務注冊與發現 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!-- web組件 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><exclusions><!--排除tomcat依賴 --><exclusion><artifactId>spring-boot-starter-tomcat</artifactId><groupId>org.springframework.boot</groupId></exclusion></exclusions></dependency><!--undertow容器 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-undertow</artifactId></dependency><!-- lombok插件 --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>
</dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>
application.yml
server:
port: 8710
spring:
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
enabled: true
application:
name: nacos-order
啟動類AppConsumer
package com.bruce;
/**
- @BelongsProject: springcloud-alibaba-nacos
- @BelongsPackage: com.bruce
- @CreateTime: 2021-02-18 13:16
- @Description: TODO
*/
@SpringBootApplication
public class AppConsumer {
public static void main(String[] args) {
SpringApplication.run(AppConsumer.class);
}
}
啟動并測試
查看注冊列表