当前位置: 首页 > news >正文

Springcloud从零开始--Eureka(一)

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

 2,找到Maven-Next

3,添加GroupId 及ArtifactId 下一步next

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

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

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

 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

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

 3,添加ArtifactId 和下一步项目名称一致 next

 4,基本不用管,想修改可以自定义路径名称

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

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

代码

<?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项目核心配置文件

 配置文件代码

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

8,添加Eureka_study启动类

 代码:

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,在启动类里面单击右键启动10,浏览器输入:http://localhost:8888/  可以看到以下界面,说明Eureka Server 服务器搭建成功

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

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 九、 系统安全(考点篇)试题
  • 无人机飞手培训:考证、组装、维修技术详解
  • 深信服技术服务工程师面试全过程分享
  • 为什么Qt源码中要用d_ptr和q_ptr
  • 力扣223题详解:矩形面积的多种解法与模拟面试
  • 两个dp题
  • MyBatis 源码解读:专栏导读与学习路线
  • python模块 - os系统交互模块
  • 订单到期关闭如何实现?
  • 中移动集团SRE人员能力提升培训圆满结课
  • 数学建模算法总结
  • 约瑟夫环问题【算法 06】
  • 看看人家写的,Controller太优雅了~【送源码】
  • 2-SAT,用连通分量编号确定答案
  • 大模型在企业数智化转型中可以做哪些事情?
  • Angular Elements 及其运作原理
  • Date型的使用
  • MySQL的数据类型
  • PAT A1017 优先队列
  • TiDB 源码阅读系列文章(十)Chunk 和执行框架简介
  • vue.js框架原理浅析
  • 阿里研究院入选中国企业智库系统影响力榜
  • 阿里云Kubernetes容器服务上体验Knative
  • 闭包--闭包作用之保存(一)
  • 分享一个自己写的基于canvas的原生js图片爆炸插件
  • 基于Vue2全家桶的移动端AppDEMO实现
  • 你真的知道 == 和 equals 的区别吗?
  • 使用权重正则化较少模型过拟合
  • 写给高年级小学生看的《Bash 指南》
  • 终端用户监控:真实用户监控还是模拟监控?
  • 你对linux中grep命令知道多少?
  • 7行Python代码的人脸识别
  • 树莓派用上kodexplorer也能玩成私有网盘
  • ​HTTP与HTTPS:网络通信的安全卫士
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (k8s)Kubernetes 从0到1容器编排之旅
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (第8天)保姆级 PL/SQL Developer 安装与配置
  • (翻译)Quartz官方教程——第一课:Quartz入门
  • (附源码)spring boot儿童教育管理系统 毕业设计 281442
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (篇九)MySQL常用内置函数
  • (七)glDrawArry绘制
  • (五)关系数据库标准语言SQL
  • ./mysql.server: 没有那个文件或目录_Linux下安装MySQL出现“ls: /var/lib/mysql/*.pid: 没有那个文件或目录”...
  • .NET CF命令行调试器MDbg入门(一)
  • .NET Core 网络数据采集 -- 使用AngleSharp做html解析
  • .net mvc部分视图
  • .net 重复调用webservice_Java RMI 远程调用详解,优劣势说明
  • .NET企业级应用架构设计系列之开场白
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • .Net下C#针对Excel开发控件汇总(ClosedXML,EPPlus,NPOI)
  • /usr/local/nginx/logs/nginx.pid failed (2: No such file or directory)
  • @RequestBody与@RequestParam:Spring MVC中的参数接收差异解析