当前位置:   article > 正文

Springcloud从零开始--Eureka(一)

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依赖代码

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <modelVersion>4.0.0</modelVersion>
  6. <groupId>com.zwj</groupId>
  7. <artifactId>Springcloud_study</artifactId>
  8. <packaging>pom</packaging>
  9. <version>1.0-SNAPSHOT</version>
  10. <modules>
  11. <module>Eureka_study</module>
  12. </modules>
  13. <!-- 1 确定spring boot的版本-->
  14. <parent>
  15. <groupId>org.springframework.boot</groupId>
  16. <artifactId>spring-boot-starter-parent</artifactId>
  17. <version>2.1.4.RELEASE</version>
  18. </parent>
  19. <!--2 确定版本-->
  20. <properties>
  21. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  22. <java.version>1.8</java.version>
  23. <spring-cloud-release.version>Greenwich.RELEASE</spring-cloud-release.version>
  24. </properties>
  25. <!-- 3 锁定sprig cloud版本-->
  26. <dependencyManagement>
  27. <dependencies>
  28. <dependency>
  29. <groupId>org.springframework.cloud</groupId>
  30. <artifactId>spring-cloud-dependencies</artifactId>
  31. <version>${spring-cloud-release.version}</version>
  32. <type>pom</type>
  33. <scope>import</scope>
  34. </dependency>
  35. </dependencies>
  36. </dependencyManagement>
  37. <!-- 4 确定spring cloud私有仓库-->
  38. <repositories>
  39. <repository>
  40. <id>spring-milestones</id>
  41. <name>Spring Milestones</name>
  42. <url>https://repo.spring.io/milestone</url>
  43. <snapshots>
  44. <enabled>false</enabled>
  45. </snapshots>
  46. </repository>
  47. </repositories>
  48. </project>

至此父项目算搭建完成

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

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

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

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

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

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

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

代码

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>Springcloud_study</artifactId>
  7. <groupId>com.zwj</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>Eureka_study</artifactId>
  12. <dependencies>
  13. <!--web起步依赖-->
  14. <dependency>
  15. <groupId>org.springframework.boot</groupId>
  16. <artifactId>spring-boot-starter-web</artifactId>
  17. </dependency>
  18. <!-- Eureka服务端 -->
  19. <dependency>
  20. <groupId>org.springframework.cloud</groupId>
  21. <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
  22. <version>2.2.1.RELEASE</version>
  23. </dependency>
  24. </dependencies>
  25. </project>

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

 配置文件代码

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

8,添加Eureka_study启动类

 代码:

  1. package com.zwj;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
  5. @EnableEurekaServer
  6. @SpringBootApplication
  7. public class EurekaApplication {
  8. public static void main(String[] args) {
  9. SpringApplication.run(EurekaApplication.class, args);
  10. }
  11. }

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/运维做开发/article/detail/1016092
推荐阅读
相关标签
  

闽ICP备14008679号