Springcloud从零开始--Eureka(一)

admin2024-08-23  10

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造轮子,它只是将各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

组成

我们快速进入学习 ,Eureka,服务注册和发现,它提供了一个服务注册中心、服务发现的客户端,还有一个方便的查看所有注册的服务的界面。 所有的服务使用Eureka的服务发现客户端来将自己注册到Eureka的服务器上。

Eureka 是 Netflix 开发的服务发现框架, SpringCloud 将它集成在自己的子项目
spring-cloud-netflix 中,实现 SpringCloud 的服务发现功能。 Eureka 包含两个组件:
Eureka Server 和 Eureka Client 。
Eureka Server 提供服务注册服务,各个节点启动后,会在 Eureka Server 中进行注
册,这样 EurekaServer 中的服务注册表中将会存储所有可用服务节点的信息,服务节点
的信息可以在界面中直观的看到。
Eureka Client 是一个 java 客户端,用于简化与 Eureka Server 的交互,客户端同时也
就别一个内置的、使用轮询 (round-robin) 负载算法的负载均衡器。在应用启动后,将会
向 Eureka Server 发送心跳 , 默认周期为 30 秒,如果 Eureka Server 在多个心跳周期内没有
接收到某个节点的心跳, Eureka Server 将会从服务注册表中把这个服务节点移除 ( 默认 90
秒 ) 。
Eureka Server 之间通过复制的方式完成数据的同步, Eureka 还提供了客户端缓存机
制,即使所有的 Eureka Server 都挂掉,客户端依然可以利用缓存中的信息消费其他服务
的 API 。综上, Eureka 通过心跳检查、客户端缓存等机制,确保了系统的高可用性、灵活
性和可伸缩性。
 

一,新建父项目:

   1,依次点击 file-New-Project

Springcloud从零开始--Eureka(一),第1张

 2,找到Maven-Next

Springcloud从零开始--Eureka(一),第2张

3,添加GroupId 及ArtifactId 下一步next Springcloud从零开始--Eureka(一),第3张

4 ,项目名称及路径,上一步GroupId 及ArtifactId添加完,这步基本不用动自动生成,直接Finish。

Springcloud从零开始--Eureka(一),第4张

5,父项目基本搭建成功,src文件夹可以删除

Springcloud从零开始--Eureka(一),第5张

6,打开父项目pom文件,导入依赖

Springcloud从零开始--Eureka(一),第6张

 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.zwj</groupId>
    <artifactId>Springcloud_study</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>Eureka_study</module>
    </modules>



    <!-- 1 确定spring boot的版本-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.4.RELEASE</version>
    </parent>
    <!--2  确定版本-->
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <java.version>1.8</java.version>
        <spring-cloud-release.version>Greenwich.RELEASE</spring-cloud-release.version>
    </properties>

    <!-- 3 锁定sprig cloud版本-->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud-release.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <!-- 4 确定spring cloud私有仓库-->
    <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>

至此父项目算搭建完成

二,搭建子项目Eureka(服务器端EurekaServer )

1,选中父项目右键单击依次:New - Module

Springcloud从零开始--Eureka(一),第7张

2,和新建父项目类似:找到Maven - next

Springcloud从零开始--Eureka(一),第8张 3,添加ArtifactId 和下一步项目名称一致 nextSpringcloud从零开始--Eureka(一),第9张

 4,基本不用管,想修改可以自定义路径名称Springcloud从零开始--Eureka(一),第10张

 5,Finish,Eureka_study子项目搭建成功

Springcloud从零开始--Eureka(一),第11张

 6,添加依赖,打开Eureka_study pom文件

Springcloud从零开始--Eureka(一),第12张

代码

<?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">
    <parent>
        <artifactId>Springcloud_study</artifactId>
        <groupId>com.zwj</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>Eureka_study</artifactId>
    <dependencies>
        <!--web起步依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- Eureka服务端 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
    </dependencies>

</project>

 7,添加Eureka_study项目核心配置文件

Springcloud从零开始--Eureka(一),第13张

Springcloud从零开始--Eureka(一),第14张

Springcloud从零开始--Eureka(一),第15张

 配置文件代码

# Tomcat
server:
  port: 8888

# Spring
spring:
  application:
    # 应用名称
    name: eureka-study
eureka:
  client:
    sevice-url:  #Eureka客户端与Eureka服务端进行交互的地址
      defaultZone: http://localhost:${server.port}/eureka
    register-with-eureka: false  #是否将自己注册到Eureka服务中,本身就是所有无需 注册

    fetch-registry: false #是否从Eureka中获取注册信息

8,添加Eureka_study启动类

Springcloud从零开始--Eureka(一),第16张 代码:

package com.zwj;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
 
@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {

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

 9,在启动类里面单击右键启动Springcloud从零开始--Eureka(一),第17张Springcloud从零开始--Eureka(一),第18张10,浏览器输入:http://localhost:8888/  可以看到以下界面,说明Eureka Server 服务器搭建成功

Springcloud从零开始--Eureka(一),第19张

下一篇:Springcloud从零开始---Zuul-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明原文出处。如若内容造成侵权/违法违规/事实不符,请联系SD编程学习网:675289112@qq.com进行投诉反馈,一经查实,立即删除!