javascript
SpringCloud(二) 服务注册与发现Eureka
????? 1.eureka是干什么的?
???????????????? 上篇說了,微服務(wù)之間需要互相之間通信,那么通信就需要各種網(wǎng)絡(luò)信息,我們可以通過使用硬編碼的方式來進(jìn)行通信,但是這種方式顯然不合適,不可能說一個微服務(wù)的地址發(fā)生變動,那么整個系統(tǒng)的所有微服務(wù)都要重新部署,顯然是不合適的,那么我們需要一個服務(wù)發(fā)現(xiàn)機(jī)制,服務(wù)消費(fèi)者通過這種機(jī)制來獲取服務(wù)提供者的網(wǎng)絡(luò)信息,并且服務(wù)提供者的網(wǎng)絡(luò)信息即使變化,服務(wù)消費(fèi)者也不必改變配置。Eureka提供的就是這樣一種服務(wù)注冊與發(fā)現(xiàn)的功能,也就是所有的服務(wù)在啟動的時候都需要把自己的網(wǎng)絡(luò)信息告訴Eureka以供所有服務(wù)使用
???????????????? 服務(wù)提供者、服務(wù)消費(fèi)者、Eureka三者之間的關(guān)系
?????????????????? (1)服務(wù)提供者在啟動的時候,將自己的網(wǎng)絡(luò)信息注冊到Eureka,Eureka存貯這些信息
?????????????????? (2)服務(wù)提供者與Eureka之間定時的發(fā)送心跳告訴Eureka我還在,如果長時間沒有發(fā)送心跳,那么就表示該服務(wù)已經(jīng)停止,就會注銷該服務(wù)
?????????????????? (3)服務(wù)消費(fèi)者可以通過Eureka查詢服務(wù)提供者的網(wǎng)絡(luò)地址,通過該地址查詢調(diào)用服務(wù)提供者的接口
????? 2.編寫Eureka server
????????????? 我們都用maven來管理依賴
??????????? 1.創(chuàng)建maven工程并添加依
???????????????????? 我用的全是最新的版本,對于不同springcloud版本和SpringBoot的兼容不同,詳細(xì)看5
1 <!--添加eureka-server依賴--> 2 <dependency> 3 <groupId>org.springframework.cloud</groupId> 4 <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> 5 </dependency><!--添加eureka-client依賴,這個依賴在這里可以不用加,如果但是如果是多個Eureka server 需要添加,因?yàn)镋ureka之間需要互相注冊--> 6 <dependency> 7 <groupId>org.springframework.cloud</groupId> 8 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> 9 </dependency> 10 <!--引入SpringCloud的依賴--> 11 <dependencyManagement> 12 <dependencies> 13 <dependency> 14 <groupId>org.springframework.cloud</groupId> 15 <artifactId>spring-cloud-dependencies</artifactId> 16 <version>Finchley.SR1</version> 17 <type>pom</type> 18 <scope>import</scope> 19 </dependency> 20 </dependencies> 21 </dependencyManagement> 22 23 <!-- 注意: 這里必須要添加,否則各種依賴有問題 推測問題在于目前部分依賴沒有上傳到中央倉庫 --> 24 <repositories> 25 <repository> 26 <id>spring-milestones</id> 27 <name>Spring Milestones</name> 28 <url>http://repo.spring.io/milestone</url> 29 <snapshots> 30 <enabled>false</enabled> 31 </snapshots> 32 </repository> 33 </repositories> 點(diǎn)擊查看代碼??????? 2.編寫配置
1 server: 2 port: 8080 3 tomcat: 4 uri-encoding: utf-8 5 eureka: 6 client: 7 #是否將自己注冊到Eureka Server,默認(rèn)為true,由于當(dāng)前應(yīng)用就是Eureka,所以設(shè)置成false 8 register-with-eureka: false 9 #表示是否從Eueka Server獲取注冊信息,默認(rèn)為true,由于當(dāng)前是單節(jié)點(diǎn)的Eureka Server,沒有其他Eureka Server ,故而設(shè)置為false 10 fetch-registry: false 11 service-url: 12 #這里是交互的地址,所有的服務(wù)注冊與查詢服務(wù)都需要通過這個地址,這里可以設(shè)置多個地址,用逗號隔開 13 defaultZone: http://localhost:8080/eureka/ 14 server: 15 enableSelfPreservation: false #關(guān)閉做我保護(hù)模式 16?????? 3.編寫啟動類
@SpringBootApplication @EnableEurekaServer //啟動一個服務(wù)注冊中心提供給其他應(yīng)用進(jìn)行對話 public class TouristRegisterCenter {public static void main(String[] args) {SpringApplication.run(TouristRegisterCenter.class, args);} }?? 整個啟動類只是加了一個@EnableEurekaServer 注解
??? 4.啟動
???? 然后我們可以看見這樣的頁面就說明恭喜你成功了????
???? 但是注意看instances currently registered with Eureka?? 這里面是我們注冊的服務(wù),這是空的(廢話,我還沒注冊呢),頁面內(nèi)容英語稍微好一點(diǎn)看看應(yīng)該就明白了,實(shí)在不行就百度翻譯吧
?
?
現(xiàn)在Eureka server已經(jīng)有了,那么我們肯定要網(wǎng)上注冊一點(diǎn)東西啊,接著我們直接copy上面這個然后做一個修改就OK了。上代碼
? 5.將微服務(wù)注冊到Eureka server
??????? 5.1? 上面那個pom里面有這個依賴,如果直接copy的可以直接忽略,但是注冊的時候主要用到的就是這個包
1 <!--添加eureka-server依賴--> 2 <dependency> 3 <groupId>org.springframework.cloud</groupId> 4 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> 5 </dependency> 點(diǎn)擊查看代碼??????? 5.2修改配置文件
1 server: 2 port: 8081 3 tomcat: 4 uri-encoding: utf-8 5 6 7 spring: 8 application: 9 name: Tourist-user-server #注冊到Eureka server 上的應(yīng)用名稱 10 11 12 eureka: 13 client: 14 service-url: 15 defaultZone: http://localhost:8080/eureka/ #Eureka server 注冊地址 16 instance: 17 prefer-ip-address: true #表示將自己的IP注冊到Eureka server ,該配置默認(rèn)false,表示將所在計(jì)算機(jī)系統(tǒng)的hostname注冊到Eureka server????????????? 關(guān)于配置或者代碼里面細(xì)節(jié)的東西我都直接寫在代碼注釋里了,畢竟方便看嘛
??????? 5.3 編寫啟動類
1 @SpringBootApplication 2 @EnableEurekaClient 3 public class TouristuserserviceApplication { 4 5 public static void main(String[] args) { 6 SpringApplication.run(TouristuserserviceApplication.class,args); 7 } 8 } 9????????????? 在這里就是把server中的@EnableEurekaServer 改成了@EnableEurekaClient ,聲明這是一個Eureka client
?
6.啟動查看
????? 首先啟動Eureka server? ,啟動成功之后再啟動Eureka client
?????? 兩個全部啟動之后我們再訪問Eureka server 看看是否注冊進(jìn)去了
??
?
?? OK!!!!成功注冊上去了,大功告成
?
7.關(guān)于版本
??? 關(guān)于springcloud版本
? 這只是springcloud版本,因?yàn)閟pringcloud基于springBoot,所以springcloud與SpringBoot的版本最好對應(yīng),詳情可以看一下GitHub上springcloud的信息,附上地址https://github.com/spring-projects/spring-cloud/wiki/Spring-Cloud-Finchley-Release-Notes
8.結(jié)束
其實(shí)關(guān)于Eureka server 總結(jié)下來就是
???? 1.添加依賴
???? 2.配置
???? 3.在啟動類添加注解,聲明這是一個Eureka server
Eureka client 也就是微服務(wù),注冊的過程也很簡單
???? 1.添加依賴
???? 2.增加配置,主要就是注冊上去的名稱和注冊地址
???? 3.在啟動類上聲明是一個Eureka client
然后就成了。。。。。。。。
?
??? 這純屬自己學(xué)習(xí),如果有什么不對的地方請大神們多多指教,小弟萬分感謝
轉(zhuǎn)載于:https://www.cnblogs.com/SunArmy/p/9556619.html
總結(jié)
以上是生活随笔為你收集整理的SpringCloud(二) 服务注册与发现Eureka的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python学习---面向对象的学习[深
- 下一篇: gradle idea java ssm