SpringCloud服務(wù)注冊和發(fā)現(xiàn)組件Eureka
本篇文章,我們來講解springcloud的服務(wù)注冊和發(fā)現(xiàn)組件,上一章節(jié)我們講解了如何搭建springcloud的多模塊項目,已經(jīng)新建了springcloud-eureka-server,springcloud-eureka-client兩個模塊,本章節(jié)就在這基礎(chǔ)上直接使用。
想要了解的請參考:一起來學(xué)Spring Cloud | 第一章 :如何搭建一個多模塊的springcloud項目
一、Eureka簡介:
1.1 什么是eureka
Eureka是一個基于REST的服務(wù),主要用于AWS云中的定位服務(wù),以實現(xiàn)中間層服務(wù)器的負(fù)載平衡和故障轉(zhuǎn)移,在 Spring Cloud 微服務(wù)架構(gòu)中通常用作注冊中心,我們稱這個服務(wù)為 Eureka Server,還有一個與之交互的客戶端稱之為 Eureka Client。
1.2 eureka的功能
Eureka 、Consul 、Zookeepe,是Springcloud支持很輕松地實現(xiàn)服務(wù)的注冊和發(fā)現(xiàn)功能的組件??催^我上一章博客的同學(xué)一定知道Eureka,Hystrix ,Ribbon,Zuul,都是 Netflix 公司開源的,一起被稱為 Spring Cloud Netflix,所以Eureka 是Spring Cloud 首選推薦的服務(wù)注冊與發(fā)現(xiàn)組件。
ps : 但是Eureka 2.0 開源工作宣告停止,所以不管后期Eureka 如何發(fā)展,但是對springcloud的影響都不是很大,畢竟還有Consul 、Zookeepe可以選擇。
1.3 eureka服務(wù)注冊與服務(wù)發(fā)現(xiàn)
服務(wù)發(fā)現(xiàn)有兩種模式:一種是客戶端發(fā)現(xiàn)模式,一種是服務(wù)端發(fā)現(xiàn)模式。Eureka采用的是客戶端發(fā)現(xiàn)模式。Eureka Client需要每30秒給Eureka Server發(fā)一次心跳,同時更新Server上最新的注冊信息到本地,如果Server多次沒有收到來自客戶端的心跳,那么在90秒內(nèi)會被Server上剔除。
二、springcloud-eureka-server配置
我們首先回顧一下上一章節(jié)的項目目錄結(jié)構(gòu):

修改springcloud-eureka-server模塊中的pom.xml文件如下:
<parent>標(biāo)簽就是引入我們第一章節(jié)新建的父工程的pom.xml文件,具體可參考:一起來學(xué)Spring Cloud | 第一章 :如何搭建一個多模塊的springcloud項目
<?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>
<parent>
<groupId>com.haly</groupId>
<artifactId>springcloud</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.haly</groupId>
<artifactId>springcloud-eureka-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-eureka-server</name>
<description>新建一個springcloud項目</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</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>${spring-cloud.version}</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>
</project>
新增springcloud-eureka-server模塊的application.properties 配置文件
在application.properties文件中加入eureka的配置項,現(xiàn)在我們使用的是.properties格式,其實工作中我們更加喜歡用.yml格式,只是語法不一樣,有興趣的同學(xué)可以去了解yml格式配置。
# 設(shè)置的eureka端口號
server.port=8761
# 設(shè)置eureka的主機(jī)地址
eureka.instance.hostname=localhost
#表示是否將自己注冊到Eureka Server,默認(rèn)為true。由于當(dāng)前應(yīng)用就是Eureka Server,故而設(shè)置為false
eureka.client.registerWithEureka=false
#表示是否從Eureka Server獲取注冊信息,默認(rèn)為true。因為這是一個單點的Eureka Server,不需要同步其他的Eureka Server節(jié)點的數(shù)據(jù),故而設(shè)置為false
eureka.client.fetchRegistry=false
#Eureka server地址,查詢服務(wù)和注冊服務(wù)都需要依賴這個地址,多個地址可用逗號(英文的)分割
eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
# 服務(wù)模塊名稱
spring.application.name=springcloud-eureka-server
新增啟動類SpringcloudEurekaServerApplication
SpringcloudEurekaServerApplication類上加上@EnableEurekaServer注解,表示這個類為Eureka Server類,雖然注解配置簡單,但是這個注解底層原理,還是做了很多事的。
ps :如果@EnableEurekaServer注解不可用,那可能是SpringCloud版本不對,可嘗試去父pom.xml文件中修改下版本version即可
package com.haly;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@EnableEurekaServer
@SpringBootApplication
public class SpringcloudEurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudEurekaServerApplication.class, args);
}
}
啟動SpringcloudEurekaServerApplication服務(wù)
在SpringcloudEurekaServerApplication類上右鍵 Run as -> spring boot app,啟動項目。
啟動項目成功后,在瀏覽器中輸入 http://localhost:8761,我們可以看到如下頁面

目前上圖紅框中,沒有eureka客戶端注冊到當(dāng)前的eureka上,接下來,我們創(chuàng)建一個eureka客戶端。
三、springcloud-eureka-client配置
修改springcloud-eureka-client模塊中,pom.xml文件如下:
<parent>標(biāo)簽就是引入我們第一章節(jié)新建的父工程的pom.xml文件,具體可參考:一起來學(xué)Spring Cloud | 第一章 :如何搭建一個多模塊的springcloud項目
<?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>
<parent>
<groupId>com.haly</groupId>
<artifactId>springcloud</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.haly</groupId>
<artifactId>springcloud-eureka-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-eureka-client</name>
<description>新建一個springcloud項目</description>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
修改springcloud-eureka-client模塊的application.properties 配置文件
ps:spring.application.name這個配置很重要,eureka可視化窗口上顯示的就是這個名字,以后服務(wù)與服務(wù)之間相互調(diào)用一般都是根據(jù)這個name
# 服務(wù)端口號 server.port=9300 # 服務(wù)名稱 spring.application.name=springcloud-eureka-client # 注冊到的eureka服務(wù)地址 eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
新加啟動類SpringcloudEurekaClientApplication
通過注解@EnableEurekaClient 表明自己是一個eurekaclient,可以注入到對應(yīng)配置的eureka上
package com.haly;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
@EnableEurekaClient
public class SpringcloudEurekaClientApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudEurekaClientApplication.class, args);
}
}
在SpringcloudEurekaClientApplication類上右鍵 Run as -> spring boot app,啟動項目。
啟動項目成功后,在瀏覽器中輸入 http://localhost:8761,我們可以看到如下頁面 ,紅色框標(biāo)記的地方,出現(xiàn)了Eureka Client的服務(wù)名稱(我們在application.properties中配置的名字)

測試springcloud-eureka-client中是否可以正常使用
新建一個業(yè)務(wù)類ClientTest,類上使用注解@RestController
@RestController注解相當(dāng)于@ResponseBody + @Controller合在一起的作用。
package com.haly;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class ClientTest {
<br> @Value("${server.port}")<br> String port;<br>
@RequestMapping("/hello")<br> public String hello(@RequestParam(value = "name", defaultValue = "young碼農(nóng)") String name) {<br> return name + ",welcome to springcloud! server port:" + port;<br> }
}
這時打開 瀏覽器,輸入http://localhost:9300/hello?name=young碼農(nóng),頁面結(jié)果如下,證明我們的項目搭建成功了,可以正常寫業(yè)務(wù)邏輯了。

四、總結(jié):
完成所有功能后,項目目錄結(jié)構(gòu)如下:

到此這篇關(guān)于SpringCloud服務(wù)注冊和發(fā)現(xiàn)組件Eureka的文章就介紹到這了,更多相關(guān)SpringCloud服務(wù)注冊和 組件Eureka內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringCloud?Eureka服務(wù)治理之服務(wù)注冊服務(wù)發(fā)現(xiàn)
- SpringCloud?Eureka服務(wù)注冊中心應(yīng)用入門詳解
- SpringCloud如何使用Eureka實現(xiàn)服務(wù)之間的傳遞數(shù)據(jù)
- SpringCloud實現(xiàn)Eureka服務(wù)注冊與發(fā)現(xiàn)
- 5分鐘搭建SpringCloud Eureka服務(wù)注冊中心的實現(xiàn)
- SpringCloud Eureka的使用教程
- Springcloud Eureka配置及集群代碼實例
- SpringCloud?Eureka應(yīng)用全面介紹
相關(guān)文章
詳解SpringBoot應(yīng)用服務(wù)啟動與安全終止
這篇文章主要介紹了SpringBoot應(yīng)用服務(wù)啟動與安全終止,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Springboot詳解RocketMQ實現(xiàn)消息發(fā)送與接收流程
這篇文章主要介紹了SpringBoot整合RocketMQ實現(xiàn)消息發(fā)送和接收功能,我們使用主流的SpringBoot框架整合RocketMQ來講解,使用方便快捷,本文分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
SpringBoot集成tika實現(xiàn)word轉(zhuǎn)html的操作代碼
Tika是一個內(nèi)容分析工具,自帶全面的parser工具類,能解析基本所有常見格式的文件,得到文件的metadata,content等內(nèi)容,返回格式化信息,本文給大家介紹了SpringBoot集成tika實現(xiàn)word轉(zhuǎn)html的操作,需要的朋友可以參考下2024-06-06
SpringBoot+MyBatis-Plus實現(xiàn)分頁的項目實踐
MyBatis-Plus是基于MyBatis的持久層增強(qiáng)工具,提供簡化CRUD、代碼生成器、條件構(gòu)造器、分頁及樂觀鎖等功能,極大簡化了開發(fā)工作量并提高了開發(fā)效率,本文就來介紹一下SpringBoot+MyBatis-Plus實現(xiàn)分頁的項目實踐,感興趣的可以了解一下2024-11-11
Java之Pattern.compile函數(shù)用法詳解
這篇文章主要介紹了Java之Pattern.compile函數(shù)用法詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08

