SpringCloud學習教程一( 服務的註冊與發現 Eureka)
本文是根據方誌明的springCloud學習教程進行個人細化,記錄個人學習的教程可能會做一些小的修改讓文章更便於理解,
原著參考案例全部採用Spring Boot 1.5.x ,Spring Cloud版本為Dalston.RELEASE
一、spring cloud簡介
spring cloud 為開發人員提供了快速構建分散式系統的一些工具,包括配置管理、服務發現、斷路器、路由、微代理、事件匯流排、全域性鎖、決策競選、分散式會話等等。它執行環境簡單,可以在開發人員的電腦上跑。另外說明spring cloud是基於springboot的,所以需要開發中對springboot有一定的瞭解,如果不瞭解的話可以看這篇文章:
注意 :
1.1 (技術前提) springBoot , spring , maven , idea ,
二、建立服務註冊中心
在這裡,我們需要用的的元件上Spring Cloud Netflix的Eureka ,eureka是一個服務註冊和發現模組。
2.1 首先建立一個maven主工程。
2.2 然後建立2個model工程:一個model工程作為服務註冊中心,即Eureka Server,另一個作為Eureka Client。
下面以建立server為例子,詳細說明建立過程:
右鍵工程->建立model-> 選擇spring initialir 如下圖:
下一步->選擇cloud discovery->eureka server ,然後一直下一步就行了。
idea自動建立完後的工程的pom.xml檔案如下:
<?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類上加:
@EnableEurekaServer
@SpringBootApplication
public class EurekaserverApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaserverApplication.class, args);
}
}
2.4 eureka是一個高可用的元件,它沒有後端快取,每一個例項註冊之後需要向註冊中心傳送心跳(因此可以在記憶體中完成),預設情況下eureka伺服器也是一個eureka客戶端,還需要一個url來定位節點。
小知識: 註冊服務預設心跳時間為30秒,當一個伺服器不可用,需要3個心跳才能讓伺服器和客戶端的元資料相同。可以使用eureka.instance.leaseRenewalIntervalInSeconds加快這個過程。在生產環境最好使用預設配置。
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 是有介面的,啟動工程,開啟瀏覽器訪問:
No application available 沒有服務被發現 ……^_^
因為沒有註冊服務當然不可能有服務被發現了。
三、建立一個服務提供者 (eureka client)
當client向server註冊時,它會提供一些元資料,例如主機和埠,URL,主頁等。Eureka server 從每個client例項接收心跳訊息。 如果心跳超時,則通常將該例項從註冊server中刪除。
建立過程同server類似,建立完pom.xml如下:
<?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.
@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配置檔案如下:
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
server:
port: 8762
spring:
application:
name: service-hi
需要指明spring.application.name,這個很重要,這在以後的服務與服務之間相互呼叫一般都是根據這個name 。
啟動工程,開啟http://localhost:8761 ,即eureka server 的網址:(就能夠在下圖發現自己的其它服務是否被註冊進來)
你會發現一個服務已經註冊在服務中了,服務名為SERVICE-HI ,埠為7862
hi forezp,i am from port:8762
原始碼下載:https://github.com/forezp/SpringCloudLearning/tree/master/chapter1
相關推薦
SpringCloud學習筆記一 服務註冊與發現
開發十年,就只剩下這套架構體系了! >>>
SpringCloud(1)服務註冊與發現Eureka
1.建立1個空白的工程 2.建立2個model工程 一個model(即SpringBoot)工程作為服務註冊中心,即Eureka Server,另一個作為Eureka Client。 Eureka Server建立完後的工程 pom.xml 檔案如下: <?xml version="1.0" e
SpringCloud學習教程一( 服務的註冊與發現 Eureka)
本文是根據方誌明的springCloud學習教程進行個人細化,記錄個人學習的教程可能會做一些小的修改讓文章更便於理解,原著參考案例全部採用Spring Boot 1.5.x ,Spring Cloud版本為Dalston.RELEASE一、spring cloud簡介spri
SpringCloud 學習記錄(一):服務註冊與發現(eureka+feign)
前面介紹過dubbo遠端介面呼叫的簡單使用,這裡我們將開始學習如何使用springcloud微服務架構中的服務註冊與發現。 一,eureka-server eureka分為服務端和客戶端兩部分, eureka server是一個服務註冊中心,類似於zookeeper,當
SpringCloud(二) 服務註冊與發現Eureka
圖片 borde 引入 vat red images .cn epo round 1.eureka是幹什麽的? 上篇說了,微服務之間需要互相之間通信,那麽通信就需要各種網絡信息,我們可以通過使用硬編碼的方式來進行通信,但是這種方式
SpringCloud的服務註冊與發現Eureka
Eureka是Netflix開源的一款提供服務註冊和發現的產品,它提供了完整的Service Registry(註冊登記)和Service Discovery(發現)實現。也是springcloud體系中最重要最核心的元件之一。 服務中心: 服務中心又稱註冊中心,管理各種服務功能包括服務的註冊、發
4--SpringCloud搭建高可用的服務註冊中心 1--SpringCloud的服務註冊與發現Eureka 1--SpringCloud的服務註冊與發現Eureka 1--SpringCloud的服務註冊與發現Eureka
我們已經介紹了1--SpringCloud的服務註冊與發現Eureka,其中,主要演示瞭如何構建和啟動服務註冊中心Eureka Server,以及如何將服務註冊到Eureka Server中,但是在之前的示例中,這個服務註冊中心是單點的,顯然這並不適合應用於線上生產環境,那麼下面在前文的基礎上,我們來看看
SpringCloud入門 ――服務註冊與發現(Eureka)
前言 Oracle轉讓Java,各種動態語言的曝光率上升,Java工程師的未來在哪裡?我覺得Spring Cloud讓未來有無限可能。拖了半年之久的Spring Cloud學習就從今天開始了。中文教材不多,而且大多都是簡單的離散的資訊,想要找到企業級的一體化解決方案很少。不過,
SpringCloud服務註冊與發現Eureka
一、建立Eureka Server作為服務註冊中心 二、新增pom.xml檔案依賴 <!--eureka server --> <dependency> <groupId>org.springframework.cloud&l
1--SpringCloud的服務註冊與發現Eureka
Eureke Eureka是Netflix開源的一款提供服務註冊和發現的產品,它提供了完整的Service Registry(註冊登記)和Service Discovery(發現)實現。也是springcloud體系中最重要最核心的元件之一。 服務中心: 服務中心又稱註冊中心,管理各種服務功
springcloud~服務註冊與發現Eureka的使用
服務註冊與發現是微服務裡的概念,也是一個基本的元件,負責服務元件的認證,即實現『你是誰』的功能,在服務註冊與發現裡,存在兩種模式,即服務端發現和客戶端發現,咱們今天說的eureka屬於客戶端發現! 下面概念來自文章:https://blog.csdn.net/forezp/article/details/7
SpringCloud 服務註冊與發現Eureka
個人學習SpringCloud系列 Eureka篇 Github Link: https://github.com/panjianlong13/SpringBoot-SpringCloud/tree/master/spring-cloud-eureka Spring Cloud簡介
spring clould(一)服務註冊與發現(Eureka)
前言 Spring Cloud是一個基於Spring Boot實現的雲應用開發工具。Spring cloud包含了很多子專案,用於解決我們服務開發中需要對面的問題,比如服務叢集、服務發現、斷路器、智慧路由。 本次開發專案中是用Spring Cloud Eureka實現在服務治理。
《springcloud — Finchley.RELEASE版》第一篇 服務註冊與發現(eureka)
構建高可用Eureka註冊中心 Eureka通過執行多個例項,使其更具有高可用性。 建立一個maven工程micro-erueka-server(micro-parent參見第一篇),pom.xml如下: <?xml version="1.0" encoding=
Spring Cloud 學習 | 第一節 服務註冊與發現
一、簡介 微服務架構當中,最總要的就是服務的提供者和消費者。消費者消費提供者提供的服務,但是消費者不應該直接呼叫提供者的服務,因為這樣的話,各個子系統之間的耦合性太強,監控,容災,負載均衡這些功能實現起來就很困難。所以需要引入註冊中心的概念,服務提供者把自己提
SpringCloud(二)服務註冊與發現
離上一篇微服務的基本概念已經過去了幾個月,在寫那篇部落格之前,自己還並未真正的使用微服務架構,很多理解還存在概念上。後面換了公司,新公司既用了SpringCloud也用了Dubbo+Zookeeper,就像上一篇文章說的,當一個服務是面向外部或者是直接提供給前端呼叫的,那麼就使用SpringCloud,而一些
0408-服務註冊與發現-Eureka常用配置
範圍 heal enabled ash 及其 流量 nds ble 地址 一、概述 參看地址:https://cloud.spring.io/spring-cloud-static/Edgware.SR3/single/spring-cloud.html#_appendi
Spring Cloud(二):服務註冊與發現 Eureka【Finchley 版】
LEDE .com Go eureka clean 英文逗號 開始 效果 sam Spring Cloud(二):服務註冊與發現 Eureka【Finchley 版】 發表於 2018-04-15 | 更新於 2018-05-07 | 上一篇主要介紹了相關理論,這一
服務註冊與發現-Eureka (高可用設計)
功能 num -a 特點 解決方案 一個 subst 同步 進程 什麽是高可用 部署需要考慮的是什麽: 1、系統遇到單點失效問題,如何能夠快速切換到其他節點完成任務 2、如何應對網絡故障,即系統如何設計成“故障開放型”(expecting failure)的 典型的問題包括
Spring Cloud構建微服務架構:服務註冊與發現 Eureka
Spring Cloud構建微服務架構:服務註冊與發現Eureka 【Dalston版】 原創 2018-04-10 宗野 Spring Cloud 已經