EureKa环境初步搭建

Eureka 介绍

整体介绍

  1. 背景:在传统应用中,组件之间的调用,通过有规范的约束的接口来实现,从而实现不同模块间良好的协作。但是被拆分成微服务后,每个微服务实例的网络地址都可能动态变化,数量也会变化,使得原来硬编码的地址失去了作用。需要一个中心化的组件来进行服务的登记和管理。
  2. 概念:实现服务治理,即管理所有的服务信息和状态。
注册中心相当于买票乘车,只看有没有票(有没有服务),有就去买票(获取注册列表),然后乘车(调用)。不必关心有多少火车在运行。
  1. 注册中心好处:不用关心有多少提供方。

  2. 注册中心有哪些:Eureka,Nacos,Consul,Zookeeper等。

  3. 服务注册与发现包括两部分,一个是服务器端,另一个是客户端。

    Server是一个公共服务,为Client提供服务注册和发现的功能,维护注册到自身的Client的相关信息,同时提供接口给Client获取注册表中其他服务的信息,使得动态变化的Client能够进行服务间的相互调用。

    Client将自己的服务信息通过一定的方式登记到Server上,并在正常范围内维护自己信息一致性,方便其他服务发现自己,同时可以通过Server获取到自己依赖的其他服务信息,完成服务调用,还内置了负载均衡器,用来进行基本的负载均衡。

  4. Eureka:是一个RESTful风格的服务,是一个用于服务发现和注册的基础组件,是搭建Spring Cloud微服务的前提之一,它屏蔽了Server和client的交互细节,使得开发者将精力放到业务上。
  5. serverA从serverB同步信息,则serverB是serverA的peer。
  6. 上面例子中如果service-url为空,且register-with-eureka,fetch-registry为true,则会报错,Cannot execute request on any known server,因为server同时也是一个client,他会尝试注册自己,所以要有一个注册中心url去注册。
  7. Netflix开源的组件。包括server和client两部分。

服务端配置:

1.创建普通maven项目

2.配置pom文件

       主要配置:

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

具体配置信息:

<?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>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.5.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>EurekaProviderId</groupId>
    <artifactId>EurekaProvider</artifactId>
    <version>1.0-SNAPSHOT</version>
    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>2020.0.3</spring-cloud.version>
    </properties>
    <dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.3.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</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>

</project>

3.配置项目启动项

EureKa环境初步搭建

 

4.配置application.properties

共3个配置文件,因为要配置高可用,所以为了方便,加了量套环境信息

EureKa环境初步搭建

 

 

 区分环境信息:

EureKa环境初步搭建

 

 

 环境信息一配置:

EureKa环境初步搭建

 

环境信息二配置:

EureKa环境初步搭建

 

 

 启动项目

1.打包

2.启动

EureKa环境初步搭建

 

 

 

 查看页面信息

http://localhost:1111/

EureKa环境初步搭建

 

 

 说明除了自己服务本身之外,还有eureka02这个副本,这样的话假设其中有一台挂掉,另外一台还是可以提供服务的

EureKa环境初步搭建

 

 挂掉一台服务,如下:1111端口挂掉,访问将保持

EureKa环境初步搭建

但是localhost:1112还是可以正常提供服务:

EureKa环境初步搭建

 

 

客户端配置

 1.修改pom文件

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

2.配置启动类

EureKa环境初步搭建

 

 3.配置环境信息properties

EureKa环境初步搭建

 

 如果spring.application.name相同的话会是一组,当系统在调用的时候

使用spring.application.name名称加接口直接去调用,如果配置了@LoadBalanced,会自动经行分流

具体参考:

http://c.biancheng.net/view/5334.html

 

EureKa环境初步搭建

上一篇:leetcode1906 查询差绝对值的最小值


下一篇:CSS3的自定义字体@font-face:将图片ICON转为字体