Eureka 簡介以及簡單示例(創建EurekaServer工程)


Eureka 是一款開源的服務注冊與發現組件,通過配合其他組件可提供負載均衡能力。

服務發現類型的技術對比:

名稱 類型 AP/CP 語言 依賴 集成 一致性算法
Eureka General AP java jvm Java Client  
Zookeeper General CP java   Client Bingding paxos
cnosul General CP go jvm HTTP/DNS library Raft

 

 

 

 

 

 

CAP理論:

C(Consistency):數據一致性,當存在多個副本的情況下, 由於網絡,機器故障,程序內部錯誤等原因出現數據寫入副本成功部分,這種情況下會出現數據的不一致,一致性的要求是在對數據的更新完成后,多個副本的數據是一一致的

A(Availability):客戶端在對集群進行讀寫的時候,能夠正常請求,但是數據的更新最終結果會有延遲,即在一定的時間內完成,也就是最終一致性

P(Partition Tolerrance):分區容忍性,即發生通信故障時,一個集群本分為多個無法互相通信的分區時,集群仍然可用

Eureka租約:

客戶端注冊服務端時,會帶有一個期限的租約, 客戶端會定期向服務端發送心跳,以用來維持租約,也就是告訴服務端“我”還活着,一旦服務端,在規定時間內沒有收到,客戶端的續約請求,則服務端會認為客戶端已經掛了,定時任務就會將其重注冊列表中刪除!

復制模式:

Eureka 使用的是對等復制,也就是集群中每個節點都可以使用讀寫操作,然后每個副本直接進行相互復制來達到數據同步更新。

示例:

創建一個父工程(eureka-test):

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.springcloud.</groupId>
<artifactId>eureka-test</artifactId>
<version>1.0-SNAPSHOT</version>


<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.2.RELEASE</version>
</parent>

<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</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>

<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
</repositories>

</project>

 

 父工程下創建一個Eureka服務工程(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>
    <parent>
        <groupId>com.springcloud.</groupId>
        <artifactId>eureka-test</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <groupId>com.eureka</groupId>
    <artifactId>eureka-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>eureka-server</name>
    <description>Eureka Server</description>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

</project>

 

配置啟動類:

package com.eureka.server;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }

}

application.yml

server:
  port: 2001
eureka:
  instance:
    hostname: eureka-server
  client:
    service-url:
      defaultZone: http://127.0.0.1:2001/eureka
    register-with-eureka: false

 port:ereuka服務的端口

 hostname:應用示例的主機名

 service-url:每個服務都有一個地址,用於集群之間的通信,默認為 localhost:8761/eureka,因為該路徑是以map的方式存儲,所以defaultZone是key,http://127.0.0.1:2001/eureka是value

 register-with-eureka:eureka復制模式是對等復制,所以當服務啟動時會根據service-url地址去進行注冊,而當前是單機模式而非集群,service-url的值為自身的路徑,這時就會出現自己注冊自己的情況,但是自身並沒有啟動成功,從而就會出現(com.sun.jersey.api.client.ClientHandlerException: java.net.ConnectException: Connection refused: connect)無法連接的錯誤,因為默認值是true所以當單機環境下,需要設置為false。

 

啟動 eureka-server 工程,並訪問http://localhost:2001/

顯示如下頁面:

配置成功!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM