摘要:創(chuàng)建過(guò)程同類(lèi)似創(chuàng)建完如下通過(guò)注解表明自己是一個(gè)僅僅是不夠的,還需要在配置文件中注明自己的服務(wù)注冊(cè)中心的地址,配置文件如下需要指明這個(gè)很重要,這在以后的服務(wù)與服務(wù)之間相互調(diào)用一般都是根據(jù)這個(gè)。
一、spring cloud簡(jiǎn)介轉(zhuǎn)載請(qǐng)標(biāo)明出處:
http://blog.csdn.net/forezp/a...
本文出自方志朋的博客
spring cloud 為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)的一些工具,包括配置管理、服務(wù)發(fā)現(xiàn)、斷路器、路由、微代理、事件總線、全局鎖、決策競(jìng)選、分布式會(huì)話等等。它運(yùn)行環(huán)境簡(jiǎn)單,可以在開(kāi)發(fā)人員的電腦上跑。另外說(shuō)明spring cloud是基于springboot的,所以需要開(kāi)發(fā)中對(duì)springboot有一定的了解,如果不了解的話可以看這篇文章:2小時(shí)學(xué)會(huì)springboot。另外對(duì)于“微服務(wù)架構(gòu)” 不了解的話,可以通過(guò)搜索引擎搜索“微服務(wù)架構(gòu)”了解下。
二、創(chuàng)建服務(wù)注冊(cè)中心在這里,我們需要用的的組件上Spring Cloud Netflix的Eureka ,eureka是一個(gè)服務(wù)注冊(cè)和發(fā)現(xiàn)模塊。
2.1 首先創(chuàng)建一個(gè)maven主工程。
2.2 然后創(chuàng)建2個(gè)model工程:一個(gè)model工程作為服務(wù)注冊(cè)中心,即Eureka Server,另一個(gè)作為Eureka Client。
下面以創(chuàng)建server為例子,詳細(xì)說(shuō)明創(chuàng)建過(guò)程:
右鍵工程->創(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 啟動(dòng)一個(gè)服務(wù)注冊(cè)中心,只需要一個(gè)注解@EnableEurekaServer,這個(gè)注解需要在springboot工程的啟動(dòng)application類(lèi)上加:
@EnableEurekaServer @SpringBootApplication public class EurekaserverApplication { public static void main(String[] args) { SpringApplication.run(EurekaserverApplication.class, args); } }
2.4 eureka是一個(gè)高可用的組件,它沒(méi)有后端緩存,每一個(gè)實(shí)例注冊(cè)之后需要向注冊(cè)中心發(fā)送心跳(因此可以在內(nèi)存中完成),在默認(rèn)情況下erureka server也是一個(gè)eureka client ,必須要指定一個(gè) 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/
通過(guò)eureka.client.registerWithEureka:false和fetchRegistry:false來(lái)表明自己是一個(gè)eureka server.
2.5 eureka server 是有界面的,啟動(dòng)工程,打開(kāi)瀏覽器訪問(wèn):
http://localhost:8761 ,界面如下:
三、創(chuàng)建一個(gè)服務(wù)提供者 (eureka client)No application available 沒(méi)有服務(wù)被發(fā)現(xiàn) ……^_^
因?yàn)闆](méi)有注冊(cè)服務(wù)當(dāng)然不可能有服務(wù)被發(fā)現(xiàn)了。
當(dāng)client向server注冊(cè)時(shí),它會(huì)提供一些元數(shù)據(jù),例如主機(jī)和端口,URL,主頁(yè)等。Eureka server 從每個(gè)client實(shí)例接收心跳消息。 如果心跳超時(shí),則通常將該實(shí)例從注冊(cè)server中刪除。
創(chuàng)建過(guò)程同server類(lèi)似,創(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
通過(guò)注解@EnableEurekaClient 表明自己是一個(gè)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ù)注冊(cè)中心的地址,application.yml配置文件如下:
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ server: port: 8762 spring: application: name: service-hi
需要指明spring.application.name,這個(gè)很重要,這在以后的服務(wù)與服務(wù)之間相互調(diào)用一般都是根據(jù)這個(gè)name 。
啟動(dòng)工程,打開(kāi)http://localhost:8761 ,即eureka server 的網(wǎng)址:
你會(huì)發(fā)現(xiàn)一個(gè)服務(wù)已經(jīng)注冊(cè)在服務(wù)中了,服務(wù)名為SERVICE-HI ,端口為7862
這時(shí)打開(kāi) http://localhost:8762/hi?name... ,你會(huì)在瀏覽器上看到 :
hi forezp,i am from port:8762
源碼下載:https://github.com/forezp/SpringCloudLearning/tree/master/chapter1
四、參考資料springcloud eureka server 官方文檔
springcloud eureka client 官方文檔
優(yōu)秀文章推薦:史上最簡(jiǎn)單的 SpringCloud 教程 | 終章
史上最簡(jiǎn)單的 SpringCloud 教程 | 第一篇: 服務(wù)的注冊(cè)與發(fā)現(xiàn)(Eureka)
史上最簡(jiǎn)單的SpringCloud教程 | 第七篇: 高可用的分布式配置中心(Spring Cloud Config)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/69909.html
摘要:接下來(lái)繼續(xù)介紹三種架構(gòu)模式,分別是查詢(xún)分離模式微服務(wù)模式多級(jí)緩存模式。分布式應(yīng)用程序可以基于實(shí)現(xiàn)諸如數(shù)據(jù)發(fā)布訂閱負(fù)載均衡命名服務(wù)分布式協(xié)調(diào)通知集群管理選舉分布式鎖和分布式隊(duì)列等功能。 SpringCloud 分布式配置 SpringCloud 分布式配置 史上最簡(jiǎn)單的 SpringCloud 教程 | 第九篇: 服務(wù)鏈路追蹤 (Spring Cloud Sleuth) 史上最簡(jiǎn)單的 S...
摘要:在服務(wù)架構(gòu)中,業(yè)務(wù)都會(huì)被拆分成一個(gè)獨(dú)立的服務(wù),服務(wù)與服務(wù)的通訊是基于的。配置文件如下在工程的啟動(dòng)類(lèi)中通過(guò)向服務(wù)中心注冊(cè)并且注冊(cè)了一個(gè)通過(guò)注冊(cè)表明,這個(gè)是負(fù)載均衡的。 轉(zhuǎn)載請(qǐng)標(biāo)明出處: http://blog.csdn.net/forezp/a...本文出自方志朋的博客 在上一篇文章,講了服務(wù)的注冊(cè)和發(fā)現(xiàn)。在服務(wù)架構(gòu)中,業(yè)務(wù)都會(huì)被拆分成一個(gè)獨(dú)立的服務(wù),服務(wù)與服務(wù)的通訊是基于http re...
摘要:一簡(jiǎn)介是一個(gè)聲明式的服務(wù)客戶端,它使得寫(xiě)服務(wù)變得更簡(jiǎn)單。同時(shí)支持可插拔的編碼器和解碼器。對(duì)添加了支持,同時(shí)在中次用相同的。 轉(zhuǎn)載請(qǐng)標(biāo)明出處: http://blog.csdn.net/forezp/a...本文出自方志朋的博客 上一篇文章,講述了通過(guò)restTemplate+ribbon去消費(fèi)服務(wù),這篇文章主要講述通過(guò)feign去消費(fèi)服務(wù)。 一、Feign簡(jiǎn)介 Feign是一個(gè)聲明式的...
摘要:它就是史上最簡(jiǎn)單的教程第三篇服務(wù)消費(fèi)者后端掘金上一篇文章,講述了通過(guò)去消費(fèi)服務(wù),這篇文章主要講述通過(guò)去消費(fèi)服務(wù)。概覽和架構(gòu)設(shè)計(jì)掘金技術(shù)征文后端掘金是基于的一整套實(shí)現(xiàn)微服務(wù)的框架。 Spring Boot 配置文件 – 在坑中實(shí)踐 - 后端 - 掘金作者:泥瓦匠鏈接:Spring Boot 配置文件 – 在坑中實(shí)踐版權(quán)歸作者所有,轉(zhuǎn)載請(qǐng)注明出處本文提綱一、自動(dòng)配置二、自定義屬性三、ran...
摘要:為了保證其高可用,單個(gè)服務(wù)又必須集群部署。為了解決這個(gè)問(wèn)題,就出現(xiàn)斷路器模型。一斷路器簡(jiǎn)介摘自官網(wǎng)已經(jīng)創(chuàng)建了一個(gè)名為的庫(kù)來(lái)實(shí)現(xiàn)斷路器模式。較底層的服務(wù)如果出現(xiàn)故障,會(huì)導(dǎo)致連鎖故障。當(dāng)對(duì)特定的服務(wù)的調(diào)用達(dá)到一個(gè)閥值是秒次斷路器將會(huì)被打開(kāi)。 轉(zhuǎn)載請(qǐng)標(biāo)明出處: http://blog.csdn.net/forezp/a...本文出自方志朋的博客 在微服務(wù)架構(gòu)中,我們將業(yè)務(wù)拆分成一個(gè)個(gè)的服務(wù),...
閱讀 2589·2021-11-25 09:43
閱讀 1867·2021-09-22 15:26
閱讀 3754·2019-08-30 15:56
閱讀 1719·2019-08-30 15:55
閱讀 1904·2019-08-30 15:54
閱讀 821·2019-08-30 15:52
閱讀 3164·2019-08-29 16:23
閱讀 900·2019-08-29 12:43