赞
踩
我们快速进入学习 ,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}/eureka
- register-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 服务器搭建成功
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。