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/

显示如下页面:

配置成功!

原文地址:https://www.cnblogs.com/shiguotao-com/p/10417740.html