前言
隨著微服務(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/。

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
可以看到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è)地址奥务,如果又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上下載代碼担神。