前言
本文主要給大家介紹關于spring cloud服務注冊與發(fā)現(xiàn)(eureka)的相關內(nèi)容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹:
一、spring cloud簡介
spring cloud 為開發(fā)人員提供了快速構建分布式系統(tǒng)的一些工具,包括配置管理、服務發(fā)現(xiàn)、斷路器、路由、微代理、事件總線、全局鎖、決策競選、分布式會話等等。它運行環(huán)境簡單,可以在開發(fā)人員的電腦上跑。另外說明spring cloud是基于springboot的,所以需要開發(fā)中對springboot有一定的了解,如果不了解的話可以看這篇文章。另外對于“微服務架構” 不了解的話,可以通過搜索引擎搜索“微服務架構”了解下。
二、創(chuàng)建服務注冊中心
在這里,我們需要用的的組件上spring cloud netflix的eureka ,eureka是一個服務注冊和發(fā)現(xiàn)模塊。
2.1 首先創(chuàng)建一個maven主工程。
2.2 然后創(chuàng)建2個model工程:一個model工程作為服務注冊中心,即eureka server,另一個作為eureka client。
下面以創(chuàng)建server為例子,詳細說明創(chuàng)建過程:
右鍵工程->創(chuàng)建model-> 選擇spring initialir 如下圖:
下一步->選擇cloud discovery->eureka server ,然后一直下一步就行了。
創(chuàng)建完后的工程的pom.xml文件如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
<?xml version= "1.0" encoding= "utf-8" ?> <project xmlns= "http://maven.apache.org/pom/4.0.0" xmlns:xsi= "http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation= "http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" > <modelversion> 4.0 . 0 </modelversion> <groupid>com.forezp</groupid> <artifactid>eurekaserver</artifactid> <version> 0.0 . 1 -snapshot</version> <packaging>jar</packaging> <name>eurekaserver</name> <description>demo project for spring boot</description> <parent> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-parent</artifactid> <version> 1.5 . 2 .release</version> <relativepath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceencoding>utf- 8 </project.build.sourceencoding> <project.reporting.outputencoding>utf- 8 </project.reporting.outputencoding> <java.version> 1.8 </java.version> </properties> <dependencies> <!--eureka server --> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-starter-eureka-server</artifactid> </dependency> <!-- spring boot test--> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> <scope>test</scope> </dependency> </dependencies> <dependencymanagement> <dependencies> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-dependencies</artifactid> <version>dalston.rc1</version> <type>pom</type> <scope> import </scope> </dependency> </dependencies> </dependencymanagement> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> <repositories> <repository> <id>spring-milestones</id> <name>spring milestones</name> <url>https: //repo.spring.io/milestone</url> <snapshots> <enabled> false </enabled> </snapshots> </repository> </repositories> </project> |
2.3 啟動一個服務注冊中心,只需要一個注解@enableeurekaserver,這個注解需要在springboot工程的啟動application類上加:
1
2
3
4
5
6
7
8
|
@enableeurekaserver @springbootapplication public class eurekaserverapplication { public static void main(string[] args) { springapplication.run(eurekaserverapplication. class , args); } } |
**2.4 **eureka是一個高可用的組件,它沒有后端緩存,每一個實例注冊之后需要向注冊中心發(fā)送心跳(因此可以在內(nèi)存中完成),在默認情況下erureka server也是一個eureka client ,必須要指定一個 server。eureka server的配置文件appication.yml:
1
2
3
4
5
6
7
8
9
10
11
|
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 沒有服務被發(fā)現(xiàn) ……^_^
因為沒有注冊服務當然不可能有服務被發(fā)現(xiàn)了。
三、創(chuàng)建一個服務提供者 (eureka client)
當client向server注冊時,它會提供一些元數(shù)據(jù),例如主機和端口,url,主頁等。eureka server 從每個client實例接收心跳消息。 如果心跳超時,則通常將該實例從注冊server中刪除。
創(chuàng)建過程同server類似,創(chuàng)建完pom.xml如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
<?xml version= "1.0" encoding= "utf-8" ?> <project xmlns= "http://maven.apache.org/pom/4.0.0" xmlns:xsi= "http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation= "http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" > <modelversion> 4.0 . 0 </modelversion> <groupid>com.forezp</groupid> <artifactid>service-hi</artifactid> <version> 0.0 . 1 -snapshot</version> <packaging>jar</packaging> <name>service-hi</name> <description>demo project for spring boot</description> <parent> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-parent</artifactid> <version> 1.5 . 2 .release</version> <relativepath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceencoding>utf- 8 </project.build.sourceencoding> <project.reporting.outputencoding>utf- 8 </project.reporting.outputencoding> <java.version> 1.8 </java.version> </properties> <dependencies> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-starter-eureka</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> <scope>test</scope> </dependency> </dependencies> <dependencymanagement> <dependencies> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-dependencies</artifactid> <version>dalston.rc1</version> <type>pom</type> <scope> import </scope> </dependency> </dependencies> </dependencymanagement> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> <repositories> <repository> <id>spring-milestones</id> <name>spring milestones</name> <url>https: //repo.spring.io/milestone</url> <snapshots> <enabled> false </enabled> </snapshots> </repository> </repositories> </project> |
通過注解@enableeurekaclient 表明自己是一個eurekaclient.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@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是不夠的,還需要在配置文件中注明自己的服務注冊中心的地址,application.yml配置文件如下:
1
2
3
4
5
6
7
8
9
|
eureka: client: serviceurl: defaultzone: http: //localhost:8761/eureka/ server: port: 8762 spring: application: name: service-hi |
需要指明spring.application.name
,這個很重要,這在以后的服務與服務之間相互調(diào)用一般都是根據(jù)這個name 。
啟動工程,打開http://localhost:8761 ,即eureka server 的網(wǎng)址:
你會發(fā)現(xiàn)一個服務已經(jīng)注冊在服務中了,服務名為service-hi ,端口為7862
這時打開 http://localhost:8762/hi?name=forezp ,你會在瀏覽器上看到 :
hi forezp,i am from port:8762
源碼下載:https://github.com/forezp/springcloudlearning/tree/master/chapter1
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
參考資料
springcloud eureka server 官方文檔
springcloud eureka client 官方文檔
原文鏈接:http://blog.csdn.net/forezp/article/details/69696915