springcloud入門系列(1)-eureka服務(wù)注冊(cè)中心

前言

隨著微服務(wù)架構(gòu)的逐漸流行,現(xiàn)在很多互聯(lián)網(wǎng)公司在兩三年前架構(gòu)都已經(jīng)轉(zhuǎn)到微服務(wù)架構(gòu)了伺绽,互聯(lián)網(wǎng)架構(gòu)也經(jīng)歷了從傳統(tǒng)ESB總線架構(gòu)-》SOA-》微服務(wù)架構(gòu)的演進(jìn)過(guò)程,我待過(guò)的幾家公司基本也都跟著潮流經(jīng)歷了這樣的一個(gè)過(guò)程。除了互聯(lián)網(wǎng)公司,之前待過(guò)的國(guó)有銀行架構(gòu)最近兩年也都在轉(zhuǎn)到微服務(wù)架構(gòu)疮蹦,有些傳統(tǒng)銀行架構(gòu)師甚至比較“激進(jìn)”的直接從ESB總線架構(gòu)轉(zhuǎn)到微服務(wù),可見(jiàn)除了互聯(lián)網(wǎng)公司傳統(tǒng)行業(yè)也都在架構(gòu)轉(zhuǎn)型茸炒,微服務(wù)框架目前國(guó)內(nèi)用的比較多的就是阿里的dubbo和今天要介紹的springcloud愕乎,springcloud在微服務(wù)方面的核心組件都來(lái)自于Netflix阵苇,在微服務(wù)架構(gòu)中服務(wù)注冊(cè)和發(fā)現(xiàn)是非常核心的一部分,今天主要講解下如何搭建一個(gè)eureka的服務(wù)注冊(cè)中心感论,并且實(shí)現(xiàn)HA高可用绅项,最后還會(huì)把之前做的springboot的demo注冊(cè)到eureka上,廢話說(shuō)了那么多比肄,那么下面就開(kāi)始上干貨啦快耿。

1. eureka服務(wù)注冊(cè)中心(單機(jī))

首先使用ide工具新建一個(gè)maven工程,在pom.xml中引入我們工程需要的庫(kù)薪前,主要是springboot相關(guān)和eureka相關(guān)的庫(kù)润努,具體的依賴庫(kù)如下:

<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka-server</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

引入工程后記得在pom.xml文件上點(diǎn)擊右鍵关斜,選擇maven->reimport將涉及到的依賴庫(kù)進(jìn)行引入示括。
包引入后創(chuàng)建Application入口類,除了和之前springboot工程不一樣的工程就是要在APplication入口類上加上eurekaserver的注解@EnableEurekaSrver痢畜,讓系統(tǒng)知道該類為Eureka的Server端垛膝。

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }

}

最后只要再增加Eureka的配置文件就可以了,這里我們依然使用yaml作為配置文件丁稀,具體語(yǔ)法可以google吼拥,還是很簡(jiǎn)單的,一句話就是用縮進(jìn)來(lái)表示層級(jí)關(guān)系线衫。

spring:
  application:
    name: eureka-service-register
server:
  port: 8761
eureka:
  instance:
    hostname: localhost

配置文件不解釋也很好理解凿可,上面的spring層級(jí)就相當(dāng)于一般property文件的spring.application.name=eureka-service-register,表示該服務(wù)的名字授账;port看字面意思就知道是服務(wù)端口的意思枯跑;hostname表示對(duì)應(yīng)的主機(jī)名,一般指向本機(jī)白热,這里配置為localhost敛助。這樣就完成了單機(jī)版的服務(wù)注冊(cè)中心,是不是很簡(jiǎn)單屋确,下面我們來(lái)啟動(dòng)下看看效果,啟動(dòng)工程后纳击,在瀏覽器地址欄輸入http://localhost:8761/

image
image

2.eureka HA多機(jī)高可用版

eureka做多機(jī)互備非常簡(jiǎn)單攻臀,這里只需要修改下application.yml就可以了焕数,將配置改為多profile配置,這樣在實(shí)際運(yùn)行部署的時(shí)候刨啸,同一套jar包只需要在啟動(dòng)的時(shí)候選擇不同的profile就可以了百匆。配置文件代碼如下,這里只列出了最基本的配置項(xiàng)呜投,eureka還有很多豐富的配置項(xiàng)加匈,可以實(shí)現(xiàn)各種服務(wù)注冊(cè)和發(fā)現(xiàn)方面的功能存璃。

spring:
  application:
    name: eureka-service-register
  profiles:
    active: node1
---
spring:
  profiles: node1
server:
  port: 8761

eureka:
  instance:
    hostname: node1
  client:
#    register-with-eureka: false
#    fetch-registry: false
    serviceUrl:
    #將register1注冊(cè)到register2上,實(shí)現(xiàn)HA
      defaultZone: http://node2:8762/eureka/
---
spring:
  profiles: node2
server:
  port: 8762

eureka:
  instance:
    hostname: node2
  client:
#    register-with-eureka: false
#    fetch-registry: false
    serviceUrl:
      defaultZone: http://node1:8761/eureka/

將eureka工程導(dǎo)出成jar包雕拼,直接在命令行運(yùn)行

java -jar eurekaserver.jar --spring.profiles.active=node1

在其他機(jī)器運(yùn)行

java -jar eurekaserver.jar --spring.profiles.active=node2

ndoe1和node2是在配置文件中配置的profile的名稱纵东,這里自己實(shí)驗(yàn)的時(shí)候?yàn)榱朔奖憧梢詫osts文件修改主機(jī)名,來(lái)實(shí)現(xiàn)在一臺(tái)機(jī)器上模擬多節(jié)點(diǎn)啥寇,找到本機(jī)的hosts文件偎球,然后找到127.0.0.1那行,在后面加上127.0.0.1 node1 node2

兩個(gè)節(jié)點(diǎn)都啟動(dòng)后的效果如圖辑甜,
image

可以看到instance里已經(jīng)有了兩個(gè)節(jié)點(diǎn)衰絮,eureka會(huì)實(shí)時(shí)查看兩個(gè)節(jié)點(diǎn)的狀態(tài),如果一臺(tái)宕機(jī)了磷醋,另一臺(tái)會(huì)一直嘗試猫牡,當(dāng)問(wèn)題節(jié)點(diǎn)恢復(fù)后會(huì)自動(dòng)重連,并且將最新的服務(wù)注冊(cè)信息同步到另一臺(tái)節(jié)點(diǎn)邓线,eureka更牛的地方在于這些服務(wù)信息除了在eureka的server端會(huì)保存淌友,在服務(wù)使用方的client端同樣會(huì)分布式保存全量的服務(wù)注冊(cè)信息,當(dāng)server端出現(xiàn)極端情況服務(wù)使用方連接不上所有的eureka server端節(jié)點(diǎn)的時(shí)候骇陈,服務(wù)使用方會(huì)使用本地保存的最新的服務(wù)提供列表找到服務(wù)提供方節(jié)點(diǎn)調(diào)用接口震庭,只要服務(wù)提供方還能繼續(xù)提供服務(wù),就能保證整體服務(wù)的正常運(yùn)轉(zhuǎn)你雌。

3. 服務(wù)提供方的服務(wù)注冊(cè)

可以復(fù)用之前寫(xiě)的springboot restful api的例子器联,也可以直接在剛才的工程中新建一個(gè)module作為服務(wù)提供方,我在demo的代碼中為了方便就直接新建了一個(gè)module作為服務(wù)提供方婿崭,其中主要有以下幾點(diǎn)要修改下拨拓,其他的代碼都和之前介紹的springboot的實(shí)例代碼一樣。
1)在啟動(dòng)類增加@EnableEurekaClient注解逛球,表示要注冊(cè)到eureka服務(wù)器上千元,既然增加了eurekaClient的注解,那么肯定要設(shè)置哪個(gè)作為eureka的server端颤绕,下面來(lái)看下作為服務(wù)提供方的application.yml配置幸海。

spring:
  application:
    name: service-provider
server:
  port: 8084
eureka:
  instance:
    prefer-ip-address: true
  client:
    serviceUrl:
      defaultZone: http://node1:8761/eureka/,http://node2:8762/eureka/

這里主要要說(shuō)明的就是最后一行定義的eureka服務(wù)端地址,可以發(fā)現(xiàn)這兩個(gè)地址就是剛才我們?cè)O(shè)置的eureka server集群的兩個(gè)地址奥务,
image

如果又3臺(tái)就在后面再增加物独,理論上來(lái)說(shuō)只寫(xiě)一臺(tái)地址也是可以的,會(huì)自動(dòng)同步其他幾臺(tái)的地址氯葬,但為了保險(xiǎn)期間還是都配置上比較好挡篓,防止配置的這臺(tái)出問(wèn)題沒(méi)有同步其他幾臺(tái)節(jié)點(diǎn)的信息。

小結(jié)

本文介紹了eureka的server端和client端的配置,并且介紹了server端和client如何配置和使用服務(wù)注冊(cè)集群來(lái)實(shí)現(xiàn)高可用官研,是不是很簡(jiǎn)單秽澳,趕緊自己動(dòng)手來(lái)實(shí)現(xiàn)一個(gè)吧,本文講到的所有代碼都傳到了git上戏羽,大家可以到git上下載代碼担神。

Git代碼地址:https://github.com/feiweiwei/eureka-server-start

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市始花,隨后出現(xiàn)的幾起案子妄讯,更是在濱河造成了極大的恐慌,老刑警劉巖酷宵,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亥贸,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡浇垦,警方通過(guò)查閱死者的電腦和手機(jī)炕置,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)溜族,“玉大人讹俊,你說(shuō)我怎么就攤上這事垦沉』褪悖” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵厕倍,是天一觀的道長(zhǎng)寡壮。 經(jīng)常有香客問(wèn)我,道長(zhǎng)讹弯,這世上最難降的妖魔是什么况既? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮组民,結(jié)果婚禮上棒仍,老公的妹妹穿的比我還像新娘。我一直安慰自己臭胜,他們只是感情好莫其,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著耸三,像睡著了一般乱陡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上仪壮,一...
    開(kāi)封第一講書(shū)人閱讀 49,985評(píng)論 1 291
  • 那天憨颠,我揣著相機(jī)與錄音,去河邊找鬼积锅。 笑死爽彤,一個(gè)胖子當(dāng)著我的面吹牛养盗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播适篙,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼爪瓜,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了匙瘪?” 一聲冷哼從身側(cè)響起铆铆,我...
    開(kāi)封第一講書(shū)人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎丹喻,沒(méi)想到半個(gè)月后薄货,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡碍论,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年谅猾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鳍悠。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡税娜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出藏研,到底是詐尸還是另有隱情敬矩,我是刑警寧澤,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布蠢挡,位于F島的核電站弧岳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏业踏。R本人自食惡果不足惜禽炬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望勤家。 院中可真熱鬧腹尖,春花似錦、人聲如沸伐脖。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)晓殊。三九已至断凶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間巫俺,已是汗流浹背认烁。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人却嗡。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓舶沛,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親窗价。 傳聞我的和親對(duì)象是個(gè)殘疾皇子如庭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

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