爲了後續項目的管理,這裏我將使用主工程與多個module的形式進行項目創建
注:使用IDEA
創建一個maven主工程
File>New>Project
填寫GroupId、 ArtifactId等信息,下一步,然後點Finish,完成主項目創建
創建註冊中心
以創建子模塊的形式創建註冊中心
右擊主項目>New>Module
選擇創建Spring Initializr進行模塊創建
中間填寫項目相關信息的截圖就省略了
選擇依賴項目,當前模塊功能是註冊中心,所以選擇Eureka 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.sean</groupId>
<artifactId>cloud-eureka-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>cloud-eureka-server</name>
<description>Spring Cloud Service Registry</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.10.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>
<spring-cloud.version>Edgware.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-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>
在工程的啓動Application類上加@EnableEurekaServer註解來啓用註冊中心
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
資源文件配置
下面是最重要的部分,註冊中心的配置
在resources文件夾下application.yml或application.properties
server:
port: 8761
eureka:
instance:
lease-expiration-duration-in-seconds: 30 //1
lease-renewal-interval-in-seconds: 10 //2
prefer-ip-address: true //3
ip-address: 192.168.0.92 //4
server:
enable-self-preservation: false //5
eviction-interval-timer-in-ms: 60000 //6
client:
register-with-eureka: false //7
fetch-registry: false //8
service-url:
defaultZone: http://${eureka.instance.ip-address}:${server.port}/eureka/ //9
- 1, 2 用來檢測 服務是否存在 是否過期的
(1) 指註冊中心在接收到最後一個心跳之後等待的時間(秒),然後才能從此視圖中刪除此實例,並禁止此實例的流量。
(2) 指註冊的客戶端服務需要向註冊中心發送心跳以指示它仍然存在的頻率(以秒爲單位)。如果在leaseExpirationDurationInSeconds中指定的時間段內未收到心跳線,則eureka服務器將從其視圖中刪除該實例,因此不允許此實例的流量 - (3)用來 開啓 是否使用ip識別服務 當該變量爲 true 時 此時 將會使用您的 內網ip去註冊服務, 當您的服務註冊中心是基於內網的服務,那麼 配置服務到這一步即可.但是如果您的各項自服務,不再同一個網段中時, 請繼續配置(4)
- 當您配置 (4) 時 即爲手動配置ip地址註冊服務, 此時 [3] 的配置將無效, 如果ip爲指定註冊中心所在的公網ip,那麼 該註冊中心將在公網可見.
(5)關閉自我保護
先來說一下自我保護機制:
自我保護機制的工作機制是如果在15分鐘內超過85%的客戶端節點都沒有正常的心跳,那麼Eureka就認爲客戶端與註冊中心出現了網絡故障,Eureka Server自動進入自我保護機制,此時會出現以下幾種情況:
1、Eureka Server不再從註冊列表中移除因爲長時間沒收到心跳而應該過期的服務。
2、Eureka Server仍然能夠接受新服務的註冊和查詢請求,但是不會被同步到其它節點上,保證當前節點依然可用。
3、當網絡穩定時,當前Eureka Server新的註冊信息會被同步到其它節點中。由於Eureka擁有自我保護機制,當其註冊表裏服務因爲網絡或其他原因出現故障而關停時,Eureka不會剔除服務註冊,而是等待其修復。這是AP的一種實現。 爲了讓其有精準的 CP健康檢查,可以採取讓其剔除不健康節點。
- (6)即是健康檢查的清理間隔(單位毫秒,默認是60*1000)
- 當爲單註冊中心時, 做爲註冊中心,本服務當然不能註冊自己 (7) ,(8) 配置爲 false 服務纔可以正常啓動,當爲多註冊中心時(7) (8) 可不配置,但是(9)必須配置爲非己 的url地址
註冊中心訪問
eureka server 是有界面的,啓動工程,打開瀏覽器訪問:
http://localhost:8761 ,界面如下:
以上註冊中心項目已經創建完畢,接下來我們要去創建一個服務註冊到該註冊中心
創建一個服務提供者 (eureka client)
- 服務端將服務註冊到註冊中心時,會提供服務端的一些數據進行”備案”,
例如主機和端口,URL,主頁等,以供後續要學習的客戶端訪問該服務端時使用 - 註冊中心配置了心跳間隔時間lease-renewal-interval-in-seconds,默認爲30秒,客戶端需要沒隔30秒像註冊中心發送一次心跳,如果超過lease-expiration-duration-in-seconds(默認90秒)的值,註冊中心則認爲該服務停止了,會將其從註冊中心裏移除
創建過程同註冊中心項目創建過程類似,其中勾選依賴項目時有一定差別,如下
創建完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.sean</groupId>
<artifactId>cloud-eureka-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>cloud-eureka-serviceA</name>
<description>Service Project</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.10.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>
<spring-cloud.version>Edgware.SR1</spring-cloud.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-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>
看別人寫的代碼,好多此處依賴中都有如下web的依賴,我在實際操作中並未引入該依賴,查看了一下spring-boot-starter-parent父類項目spring-boot-dependencies中已經存在web的依賴,所以此處不用添加,也可能跟SpringBoot的版本有關,具體細節沒有詳細去追究,大拿如果知道,望告知小弟
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
通過註解@EnableEurekaClient 表明自己是一個eurekaclient.
@SpringBootApplication
@EnableEurekaClient
public class EurekaServiceApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServiceApplication.class, args);
}
}
資源文件application.yml配置
默認是.properties文件,SpringBoot 資源文件支持以下三種格式的文件
application.yml application.yaml application.properties
server:
port: 8081
spring:
application:
name: serviceA
eureka:
client:
service-url:
defaultZone: http://192.168.0.92:8761/eureka/
需要指明spring.application.name,以後服務之間調用一般是通過這個配置值去調用
新建Controller類向外提供接口服務
@RestController
@RequestMapping("/index")
public class IndexController {
@Value("${server.port}")
String port;
@RequestMapping("/hi")
public String home() {
return "hi "+",i am from port:" + port;
}
}
啓動服務(保證註冊中心爲啓動狀態),刷新註冊中心,會發現註冊中心已經出現了槓桿啓動的項目