史上最簡單的 SpringCloud 教程 | 第一篇: 服務的註冊與發現(Eureka)
最新Finchley版本請訪問:
https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f1-eureka/
或者
http://blog.csdn.net/forezp/article/details/81040925
spring cloud 為開發人員提供了快速構建分布式系統的一些工具,包括配置管理、服務發現、斷路器、路由、微代理、事件總線、全局鎖、決策競選、分布式會話等等。它運行環境簡單,可以在開發人員的電腦上跑。另外說明spring cloud是基於springboot的,所以需要開發中對springboot有一定的了解,如果不了解的話可以看這篇文章:2小時學會springboot。另外對於“微服務架構” 不了解的話,可以通過搜索引擎搜索“微服務架構”了解下。
在這裏,我們需要用的的組件上Spring Cloud Netflix的Eureka ,eureka是一個服務註冊和發現模塊。
2.1 首先創建一個maven主工程。
**2.2 然後創建2個model工程:**一個model工程作為服務註冊中心,即Eureka Server,另一個作為Eureka Client。
下面以創建server為例子,詳細說明創建過程:
右鍵工程->創建model-> 選擇spring initialir 如下圖:
下一步->選擇cloud discovery->eureka server ,然後一直下一步就行了。
創建完後的工程的pom.xml文件如下:
2.3 啟動一個服務註冊中心,只需要一個註解@EnableEurekaServer,這個註解需要在springboot工程的啟動application類上加:
**2.4 **eureka是一個高可用的組件,它沒有後端緩存,每一個實例註冊之後需要向註冊中心發送心跳(因此可以在內存中完成),在默認情況下erureka server也是一個eureka client ,必須要指定一個 server。eureka server的配置文件appication.yml:
通過eureka.client.registerWithEureka:false和fetchRegistry:false來表明自己是一個eureka server.
2.5 eureka server 是有界面的,啟動工程,打開瀏覽器訪問:
http://localhost:8761 ,界面如下:
No application available 沒有服務被發現 ……_
因為沒有註冊服務當然不可能有服務被發現了。
當client向server註冊時,它會提供一些元數據,例如主機和端口,URL,主頁等。雅思培訓一般多少錢Eureka server 從每個client實例接收心跳消息。 如果心跳超時,則通常將該實例從註冊server中刪除。
創建過程同server類似,創建完pom.xml如下:
通過註解@EnableEurekaClient 表明自己是一個eurekaclient.
僅僅@EnableEurekaClient是不夠的,還需要在配置文件中註明自己的服務註冊中心的地址,application.yml配置文件如下:
需要指明spring.application.name,這個很重要,這在以後的服務與服務之間相互調用一般都是根據這個name 。
啟動工程,打開http://localhost:8761 ,即eureka server 的網址:
你會發現一個服務已經註冊在服務中了,服務名為SERVICE-HI ,端口為7862
這時打開 http://localhost:8762/hi?name=forezp ,你會在瀏覽器上看到 :
hi forezp,i am from port:8762
源碼下載:https://github.com/forezp/SpringCloudLearning/tree/master/chapter1
springcloud eureka server 官方文檔
springcloud eureka client 官方文檔
- 史上最簡單的 SpringCloud 教程 | 終章
- 史上最簡單的 SpringCloud 教程 | 第一篇: 服務的註冊與發現(Eureka)
- 史上最簡單的SpringCloud教程 | 第七篇: 高可用的分布式配置中心(Spring Cloud Config)
史上最簡單的 SpringCloud 教程 | 第一篇: 服務的註冊與發現(Eureka)