Spring Cloud Alibaba Nacos 服務(wù)注冊(cè)與發(fā)現(xiàn)功能實(shí)現(xiàn)

Nacos 是 Spring Cloud Alibaba 中一個(gè)重要的組成部分,它提供了兩個(gè)重要的功能:服務(wù)注冊(cè)與發(fā)現(xiàn)和統(tǒng)一的配置中心功能戳气。

服務(wù)注冊(cè)與發(fā)現(xiàn)功能解決了微服務(wù)集群中磷仰,調(diào)用者和服務(wù)提供者連接管理和請(qǐng)求轉(zhuǎn)發(fā)的功能牧抽,讓程序的開發(fā)者無需過多的關(guān)注服務(wù)提供者的穩(wěn)定性和健康程度以及調(diào)用地址,因?yàn)檫@些都可以依靠 Nacos 進(jìn)行監(jiān)測(cè)胸懈、管理和自動(dòng)轉(zhuǎn)發(fā)交汤。

試想一下雏赦,當(dāng)一個(gè)系統(tǒng)被部署多個(gè)之后,如何確定要調(diào)用哪一個(gè)(服務(wù))實(shí)例芙扎?當(dāng)某個(gè)被調(diào)用的實(shí)例出現(xiàn)問題時(shí)星岗,又如何將請(qǐng)求轉(zhuǎn)發(fā)到其他實(shí)例上?這些問題都是微服務(wù)架構(gòu)中現(xiàn)實(shí)存在的問題纵顾,然而使用 Nacos 就可以輕松的解決這些問題伍茄。并且 Nacos 也提供了統(tǒng)一的配置中心,解決了之前項(xiàng)目配置文件存放在本地或 github 上的安全性問題施逾,并且支持動(dòng)態(tài)修改和統(tǒng)一維護(hù)配置文件的功能敷矫。

1.Nacos 簡(jiǎn)介

Nacos 是 Dynamic Naming and Configuration Service 的首字母簡(jiǎn)稱;它是?個(gè)更易于構(gòu)建云原生應(yīng)用的動(dòng)態(tài)服務(wù)發(fā)現(xiàn)汉额、配置管理和服務(wù)管理的平臺(tái)曹仗。

官網(wǎng):nacos.io/

倉庫源碼:github.com/alibaba/nac…

2.Nacos 生態(tài)

Nacos 幾乎支持所有主流語言,其中 Java/Golang/Python 已經(jīng)支持 Nacos 2.0 長(zhǎng)鏈接協(xié)議蠕搜,能最大限度發(fā)揮 Nacos 性能怎茫。阿里微服務(wù) DNS(Dubbo+Nacos+
Spring-cloud-alibaba/Seata/Sentinel)最佳實(shí)踐,是 Java 微服務(wù)生態(tài)最佳解決方案。

3.Nacos 快速部署

Nacos 支持 3 種部署模式:

  1. 單機(jī)部署
  2. 集群部署
  3. 多集群部署

Nacos 安裝方式有以下 2 種:

  1. 使用源碼安裝轨蛤。
  2. 使用已編譯好的安裝包進(jìn)行安裝蜜宪。

本文我們將使用第一種方式加 Docker,來快速部署 Nacos 服務(wù)器端祥山。

因?yàn)?Docker 方式安裝和卸載都比較方便圃验,所以本文就采用此方式來演示 Nacos 的安裝,其他安裝方式缝呕,詳見官網(wǎng):nacos.io/zh-cn/docs/…

3.1 預(yù)備環(huán)境準(zhǔn)備

Nacos 依賴 Java 環(huán)境來運(yùn)行澳窑,如果您是從代碼開始構(gòu)建并運(yùn)行 Nacos,還需要為此配置 Maven 環(huán)境供常,請(qǐng)確保是在以下版本環(huán)境中安裝使用:

  • 64 bit OS摊聋,支持 Linux/Unix/Mac/Windows,推薦選用 Linux/Unix/Mac栈暇。
  • 64 bit JDK 1.8+麻裁。
  • Maven 3.2.x+。

因?yàn)楸疚氖褂玫氖?Nacos + Docker 的方式進(jìn)行部署的瞻鹏,所以沒有安裝 Docker 的同學(xué)悲立,自行搜索安裝哦。

安裝 Open JDK 8

yum -y install java-1.8.0-openjdk-devel.x86_64

安裝完之后新博,使用 java -version 檢查是否安裝成功薪夕,如下圖所示:

若顯示具體的 Java 版本則表示安裝成功。

3.2 下載 Nacos

本文使用 git 的方式來下載 Nacos 源碼包赫悄,所以需要使用以下命令來先安裝 git:

yum -y install git

下載 Nacos 源碼:

git clone github.com/nacos-group…

下載完成如下圖所示:

進(jìn)入 Nacos 目錄:

cd nacos-docker

3.3 啟動(dòng) Nacos 服務(wù)

Nacos 的運(yùn)行是需要數(shù)據(jù)庫的原献,它支持兩種數(shù)據(jù)庫:本地?cái)?shù)據(jù)庫 Derby、和 MySQL 數(shù)據(jù)庫埂淮。 所以對(duì)應(yīng)的啟動(dòng)命令有以下幾種:

  • Derby 數(shù)據(jù)庫運(yùn)行單機(jī)模式:docker-compose -f example/standalone-derby.yaml up
  • MySQL 5.7 數(shù)據(jù)庫運(yùn)行單機(jī)模式:docker-compose -f example/standalone-mysql-5.7.yaml up
  • MySQL 8 數(shù)據(jù)庫運(yùn)行單機(jī)模式:docker-compose -f example/standalone-mysql-8.yaml up

集群模式啟動(dòng):docker-compose -f
example/cluster-hostname.yaml up

啟動(dòng)成功如下圖所示:

3.3 訪問Nacos

啟動(dòng)成功之后姑隅,就可以使用
http://127.0.0.1:8848/nacos/#/login 來訪問 Nacos 的管理控制臺(tái)了,如下圖所示:

用戶名和密碼都輸入 nacos 就可以進(jìn)入系統(tǒng)了倔撞,如下圖所示:

3.4 常見報(bào)錯(cuò)問題

3.4.1 docker-compose 命令未找到

docker-compose 是用于定義和運(yùn)行多容器 Docker 應(yīng)用程序的編排工具讲仰。使用 docker-compose 后不再需要逐一創(chuàng)建和啟動(dòng)容器。您可以使用 YML 文件來配置應(yīng)用程序需要的所有服務(wù)痪蝇,然后使用一個(gè)命令鄙陡,就可以從 YML 文件配置中創(chuàng)建并啟動(dòng)所有服務(wù)。 但是 docker-compose 需要單獨(dú)安裝躏啰,否則會(huì)出現(xiàn)以下錯(cuò)誤:

解決方案:

cd /usr/local/bin
wget https://github.com/docker/compose/releases/download/1.14.0-rc2/docker-compose-Linux-x86_64
rename docker-compose-Linux-x86_64 docker-compose docker-compose-Linux-x86_64
chmod +x /usr/local/bin/docker-compose
docker-compose version

安裝成功如下圖所示:

3.4.2 image:invalid reference format

使用 docker-compose 可能會(huì)提示“ERROR: no such image: nacos/nacos-server:: invalid reference format”趁矾,無效的參數(shù)格式,如下圖所示:

解決方案:修改 Nacos 源碼中
example/standalone-mysql-5.7.yaml 的配置項(xiàng)给僵,將“image: nacos/nacos-server:{{NACOS_VERSION}}”毫捣,修改為:“image: nacos/nacos-server:latest”。

4.Spring Cloud Alibaba 服務(wù)注冊(cè)

服務(wù)注冊(cè)者也就是生產(chǎn)者,是微服務(wù)中的服務(wù)提供者蔓同。它是以 Spring Boot 項(xiàng)目為基礎(chǔ)創(chuàng)建的饶辙,具體操作步驟如下:

創(chuàng)建項(xiàng)目使用阿里云的地址 start.aliyun.com 來創(chuàng)建 Spring Cloud Alibaba Nacos 項(xiàng)目,點(diǎn)擊下一步 Next牌柄,如下圖所示:

增加 Nacos Service Discovery 框架支持畸悬,如下圖所示:

再添加 Spring Web(Spring MVC)框架的支持,最后點(diǎn)擊 Finish 完成項(xiàng)目創(chuàng)建珊佣。

4.1 項(xiàng)目依賴

Spring Cloud Alibaba Nacos 項(xiàng)目主要有兩個(gè)依賴項(xiàng),如下內(nèi)容所示:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

4.2 修改配置文件

在配置文件 application.properties 中要填寫 Nacos 的相關(guān)信息披粟,具體內(nèi)容如下:

# 應(yīng)用名稱(也是 Nacos 中的服務(wù)名)
spring.application.name=spring-cloud-nacos-producer
# 應(yīng)用服務(wù) WEB 訪問端口
server.port=8082
# Nacos認(rèn)證信息
spring.cloud.nacos.discovery.username=nacos
spring.cloud.nacos.discovery.password=nacos
# Nacos 服務(wù)發(fā)現(xiàn)與注冊(cè)配置咒锻,其中子屬性 server-addr 指定 Nacos 服務(wù)器主機(jī)和端口
spring.cloud.nacos.discovery.server-addr=mse-6d50f4f0-p.nacos-ans.mse.aliyuncs.com:8848
# 注冊(cè)到 nacos 的指定 namespace,默認(rèn)為 public
spring.cloud.nacos.discovery.namespace=public

4.3 添加代碼

接下來添加一個(gè) Restful API 的接口守屉,給后面的服務(wù)調(diào)用者使用惑艇,具體實(shí)現(xiàn)代碼如下:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
@EnableDiscoveryClient
public class SpringCloudNacosProducerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudNacosProducerApplication.class, args);
    }

    @RequestMapping("/sayhi/{name}")
    public String sayHi(@PathVariable String name) {
        return "Hi Nacos Discovery " + name;
    }
}

編寫完代碼之后,運(yùn)行項(xiàng)目拇泛,觀察 Nacos 中的服務(wù)列表就可以看到此項(xiàng)目滨巴,如下圖所示:

經(jīng)過以上操作,我們創(chuàng)建的 Spring Cloud Alibaba 的項(xiàng)目就被注冊(cè)到 Nacos 中了俺叭,其他程序也可以通過 Nacos 對(duì)它進(jìn)行調(diào)用了恭取。

5.Spring Cloud Alibaba 服務(wù)發(fā)現(xiàn)

與上面創(chuàng)建方式類似,接下來我們?cè)賱?chuàng)建一個(gè)服務(wù)調(diào)用者熄守,也叫做消費(fèi)者來調(diào)用上面框架中的 sayhi 方法蜈垮,具體操作步驟如下。

5.1 創(chuàng)建項(xiàng)目

5.2 修改配置文件

# 應(yīng)用名稱
spring.application.name=springcloud-nacos-consumer
# 應(yīng)用服務(wù) WEB 訪問端口
server.port=8082
# Nacos幫助文檔: https://nacos.io/zh-cn/docs/concepts.html
# Nacos認(rèn)證信息
spring.cloud.nacos.discovery.username=nacos
spring.cloud.nacos.discovery.password=nacos
# Nacos 服務(wù)發(fā)現(xiàn)與注冊(cè)配置裕照,其中子屬性 server-addr 指定 Nacos 服務(wù)器主機(jī)和端口
spring.cloud.nacos.discovery.server-addr=82.157.146.10:8848
# 注冊(cè)到 nacos 的指定 namespace攒发,默認(rèn)為 public
spring.cloud.nacos.discovery.namespace=public

5.3 添加代碼

消費(fèi)者的實(shí)現(xiàn)代碼有兩個(gè)類,在啟動(dòng)類中添加一個(gè) RestTemplate 的 Bean 對(duì)象晋南,用于提供 Restful API 的請(qǐng)求惠猿,啟動(dòng)類的具體實(shí)現(xiàn)代碼如下:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
@EnableDiscoveryClient
public class SpringcloudNacosConsumerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringcloudNacosConsumerApplication.class, args);
    }

    @LoadBalanced
    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

消費(fèi)者的具體實(shí)現(xiàn)代碼如下:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@RestController
public class TestController {
    @Autowired
    private RestTemplate restTemplate;

    @RequestMapping("/hi")
    public String hi(String name) {
        // 調(diào)用生產(chǎn)者 sayhi 方法,并返回結(jié)果
        return restTemplate.getForObject("http://spring-cloud-nacos-producer/sayhi/" + name,
                String.class);
    }
}

添加完代碼之后负间,運(yùn)行程序偶妖,在 Nacos 的服務(wù)列表中可看到以下內(nèi)容:

之后訪問消費(fèi)者的 hi 方法,讓其調(diào)用生產(chǎn)者的實(shí)現(xiàn)效果如下:

從上述結(jié)果可以看出唉擂,消費(fèi)者通過 Nacos 已經(jīng)成功的調(diào)用到了生產(chǎn)者
spring-cloud-nacos-producer 中的 sayhi 方法了餐屎。

小結(jié)

Nacos 提供了兩個(gè)重要的功能:服務(wù)注冊(cè)與發(fā)現(xiàn)和統(tǒng)一配置中心的功能,它提供了 3 種部署方式:?jiǎn)螜C(jī)部署玩祟、集群部署和多集群部署腹缩,以及兩種安裝方式:源碼安裝和安裝包安裝。我們使用的是 Docker 加 Nacos 源碼的方式來安裝和部署 Nacos 的。Nacos 服務(wù)注冊(cè)和發(fā)現(xiàn)都需要添加 Nacos Service Discovery 框架的支持藏鹊,且在配置文件中配置相應(yīng)的 Nacos 信息润讥,才可以正確的實(shí)現(xiàn)服務(wù)的注冊(cè)和發(fā)現(xiàn)功能。

參考&鳴謝

《Nacos框架與原理》

作者:Java中文社群
鏈接:
https://juejin.cn/post/7061603853459783688

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末盘寡,一起剝皮案震驚了整個(gè)濱河市楚殿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌竿痰,老刑警劉巖脆粥,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異影涉,居然都是意外死亡变隔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門蟹倾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來匣缘,“玉大人,你說我怎么就攤上這事鲜棠〖〕” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵豁陆,是天一觀的道長(zhǎng)柑爸。 經(jīng)常有香客問我,道長(zhǎng)献联,這世上最難降的妖魔是什么竖配? 我笑而不...
    開封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮里逆,結(jié)果婚禮上进胯,老公的妹妹穿的比我還像新娘。我一直安慰自己原押,他們只是感情好胁镐,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著诸衔,像睡著了一般盯漂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上笨农,一...
    開封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天就缆,我揣著相機(jī)與錄音,去河邊找鬼谒亦。 笑死竭宰,一個(gè)胖子當(dāng)著我的面吹牛空郊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播切揭,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼狞甚,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了廓旬?” 一聲冷哼從身側(cè)響起哼审,我...
    開封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎孕豹,沒想到半個(gè)月后涩盾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡励背,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年旁赊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片椅野。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖籍胯,靈堂內(nèi)的尸體忽然破棺而出竟闪,到底是詐尸還是另有隱情,我是刑警寧澤杖狼,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布炼蛤,位于F島的核電站,受9級(jí)特大地震影響蝶涩,放射性物質(zhì)發(fā)生泄漏理朋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一绿聘、第九天 我趴在偏房一處隱蔽的房頂上張望嗽上。 院中可真熱鬧,春花似錦熄攘、人聲如沸兽愤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽浅萧。三九已至,卻和暖如春哲思,著一層夾襖步出監(jiān)牢的瞬間洼畅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國打工棚赔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留帝簇,地道東北人徘郭。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像己儒,于是被迫代替她去往敵國和親崎岂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容