這篇文章將為大家詳細(xì)講解有關(guān)Spring Cloud中服務(wù)注冊與發(fā)現(xiàn)Eureka的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括長陽網(wǎng)站建設(shè)、長陽網(wǎng)站制作、長陽網(wǎng)頁制作以及長陽網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,長陽網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到長陽省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
spring cloud 為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)的一些工具,包括配置管理、服務(wù)發(fā)現(xiàn)、斷路器、路由、微代理、事件總線、全局鎖、決策競選、分布式會話等等。它運(yùn)行環(huán)境簡單,可以在開發(fā)人員的電腦上跑。另外說明spring cloud是基于springboot的,所以需要開發(fā)中對springboot有一定的了解,如果不了解的話可以看這篇文章:2小時(shí)學(xué)會springboot。另外對于“微服務(wù)架構(gòu)” 不了解的話,可以通過搜索引擎搜索“微服務(wù)架構(gòu)”了解下。
二、創(chuàng)建服務(wù)注冊中心
在這里,我們需要用的的組件上Spring Cloud Netflix的Eureka ,eureka是一個服務(wù)注冊和發(fā)現(xiàn)模塊。
2.1 首先創(chuàng)建一個maven主工程。
2.2 然后創(chuàng)建2個model工程:一個model工程作為服務(wù)注冊中心,即Eureka Server,另一個作為Eureka Client。
下面以創(chuàng)建server為例子,詳細(xì)說明創(chuàng)建過程:
右鍵工程->創(chuàng)建model-> 選擇spring initialir 如下圖:
下一步->選擇cloud discovery->eureka server ,然后一直下一步就行了。
創(chuàng)建完后的工程的pom.xml文件如下:
4.0.0 com.forezp eurekaserver 0.0.1-SNAPSHOT jar eurekaserver Demo project for Spring Boot org.springframework.boot spring-boot-starter-parent 1.5.2.RELEASE UTF-8 UTF-8 1.8 org.springframework.cloud spring-cloud-starter-eureka-server org.springframework.boot spring-boot-starter-test test org.springframework.cloud spring-cloud-dependencies Dalston.RC1 pom import org.springframework.boot spring-boot-maven-plugin spring-milestones Spring Milestones https://repo.spring.io/milestone false
2.3 啟動一個服務(wù)注冊中心,
只需要一個注解@EnableEurekaServer,這個注解需要在springboot工程的啟動application類上加:
@EnableEurekaServer @SpringBootApplication public class EurekaserverApplication { public static void main(String[] args) { SpringApplication.run(EurekaserverApplication.class, args); } }
2.4 eureka是一個高可用的組件
每一個實(shí)例注冊之后需要向注冊中心發(fā)送心跳(因此可以在內(nèi)存中完成),在默認(rèn)情況下erureka server也是一個eureka client ,必須要指定一個 server。eureka server的配置文件appication.yml:
server: port: 8761 eureka: instance: hostname: localhost client: registerWithEureka: false fetchRegistry: false serviceUrl: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
通過eureka.client.registerWithEureka:false和fetchRegistry:false來表明自己是一個eureka server.
2.5 eureka server 是有界面的,啟動工程,打開瀏覽器訪問: http://localhost:8761 ,界面如下:
No application available 沒有服務(wù)被發(fā)現(xiàn) ……^_^ 因?yàn)闆]有注冊服務(wù)當(dāng)然不可能有服務(wù)被發(fā)現(xiàn)了。
三、創(chuàng)建一個服務(wù)提供者 (eureka client)
當(dāng)client向server注冊時(shí),它會提供一些元數(shù)據(jù),例如主機(jī)和端口,URL,主頁等。Eureka server 從每個client實(shí)例接收心跳消息。 如果心跳超時(shí),則通常將該實(shí)例從注冊server中刪除。
創(chuàng)建過程同server類似,創(chuàng)建完pom.xml如下:
4.0.0 com.forezp service-hi 0.0.1-SNAPSHOT jar service-hi Demo project for Spring Boot org.springframework.boot spring-boot-starter-parent 1.5.2.RELEASE UTF-8 UTF-8 1.8 org.springframework.cloud spring-cloud-starter-eureka org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-test test org.springframework.cloud spring-cloud-dependencies Dalston.RC1 pom import org.springframework.boot spring-boot-maven-plugin spring-milestones Spring Milestones https://repo.spring.io/milestone false
通過注解@EnableEurekaClient 表明自己是一個eurekaclient.
@SpringBootApplication @EnableEurekaClient @RestController public class ServiceHiApplication { public static void main(String[] args) { SpringApplication.run(ServiceHiApplication.class, args); } @Value("${server.port}") String port; @RequestMapping("/hi") public String home(@RequestParam String name) { return "hi "+name+",i am from port:" +port; } }
僅僅@EnableEurekaClient是不夠的,還需要在配置文件中注明自己的服務(wù)注冊中心的地址,application.yml配置文件如下:
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ server: port: 8762 spring: application: name: service-hi
需要指明spring.application.name,這個很重要,這在以后的服務(wù)與服務(wù)之間相互調(diào)用一般都是根據(jù)這個name 。 啟動工程,打開http://localhost:8761 ,即eureka server 的網(wǎng)址:
你會發(fā)現(xiàn)一個服務(wù)已經(jīng)注冊在服務(wù)中了,服務(wù)名為SERVICE-HI ,端口為7862
這時(shí)打開 http://localhost:8762/hi?name=forezp ,你會在瀏覽器上看到 :
hi forezp,i am from port:8762
關(guān)于“Spring Cloud中服務(wù)注冊與發(fā)現(xiàn)Eureka的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。