史上最簡單的 SpringCloud 教程 | 第一篇: 服務的註冊與發現(Eureka)

首先:歡迎各位學習java和大數據的程序員朋友們加入Java交流學習羣: 721506929,羣內提供免費的學習資料,有需要的朋友可以進羣來學習。

https://www.fangzhipeng.com/springcloud/2017/06/01/sc01-eureka.html

本文出自方誌朋的博客

一、spring cloud簡介

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 如下圖:


16aa099161e304ee?w=600&h=515&f=jpeg&s=22807

下一步->選擇cloud discovery->eureka server ,然後一直下一步就行了。


16aa0991658ba000?w=600&h=648&f=jpeg&s=24441

創建完後的工程的pom.xml文件如下:

16aa09915b952ebe?w=640&h=497&f=jpeg&s=36407


16aa09915de2673d?w=640&h=512&f=jpeg&s=27801


16aa09915bcf6e3d?w=909&h=147&f=jpeg&s=7433

2.3 啓動一個服務註冊中心,只需要一個註解@EnableEurekaServer,這個註解需要在springboot工程的啓動application類上加:

16aa0991619fc3d5?w=915&h=210&f=jpeg&s=13330

**2.4 **eureka是一個高可用的組件,它沒有後端緩存,每一個實例註冊之後需要向註冊中心發送心跳(因此可以在內存中完成),在默認情況下erureka server也是一個eureka client ,必須要指定一個 server。eureka server的配置文件application.yml:

16aa099176d312ba?w=915&h=253&f=jpeg&s=15751

通過eureka.client.registerWithEureka:false和fetchRegistry:false來表明自己是一個eureka server.

2.5 eureka server 是有界面的,啓動工程,打開瀏覽器訪問:

http://localhost:8761 ,界面如下:


16aa099177637150?w=600&h=331&f=jpeg&s=23805

No application available 沒有服務被發現 ……_

因爲沒有註冊服務當然不可能有服務被發現了。

三、創建一個服務提供者 (eureka client)

當client向server註冊時,它會提供一些元數據,例如主機和端口,URL,主頁等。Eureka server 從每個client實例接收心跳消息。 如果心跳超時,則通常將該實例從註冊server中刪除。

創建過程同server類似,創建完pom.xml如下:

16aa0991815896b6?w=640&h=484&f=jpeg&s=32821


16aa099182301f2c?w=640&h=493&f=jpeg&s=26083


16aa099183dcda61?w=911&h=226&f=jpeg&s=11321


通過註解@EnableEurekaClient 表明自己是一個eurekaclient.

16aa09918e27ac6f?w=640&h=275&f=jpeg&s=13950

僅僅@EnableEurekaClient是不夠的,還需要在配置文件中註明自己的服務註冊中心的地址,application.yml配置文件如下:

16aa09918fc769e5?w=914&h=230&f=jpeg&s=11010

需要指明spring.application.name,這個很重要,這在以後的服務與服務之間相互調用一般都是根據這個name 。

啓動工程,打開http://localhost:8761 ,即eureka server 的網址:


16aa09919ace5cc9?w=600&h=229&f=jpeg&s=17373

你會發現一個服務已經註冊在服務中了,服務名爲SERVICE-HI ,端口爲7862

這時打開 http://localhost:8762/hi?name=forezp ,你會在瀏覽器上看到 :

hi forezp,i am from port:8762

最後:歡迎各位學習java和大數據的朋友們加入Java交流學習羣: 721506929

點擊鏈接加入羣聊【java交流學習羣】:https://jq.qq.com/?_wv=1027&k=5mH1lvO羣內提供免費的架構資料還有:Java工程化、高性能及分佈式、高性能、深入淺出。高架構。性能調優、Spring,MyBatis,Netty源碼分析和大數據等多個知識點高級進階乾貨的免費直播講解 可以進來一起學習交流哦~




16aa09d2fee3acc8?w=198&h=198&f=jpeg&s=10423



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章