SpringCloud对于注册中心提供了很多的选择,如下所示:
- 满足CAP中的Eureka-通过集群保证高可用,集群中每一个节点都是对等的,数据的一致通过节点相互通信来保证,所以无法保证强一致性,本身提供了自我保护机制(如果eureka服务在15分钟之内有超过85%的client无法通信,那么可能eureka与client出现来网络问题,eureka服务开启自我保护机制,不会再剔除90s内没有和eureka续约的client了。这个机制在开发阶段需要关闭),极大保证了服务的高可用。只要集群中存在一个节点都可以对外提供服务。
- 满足CAP中的CP的zookeeper-基于本身的ZAB协议保证数据的强一致性,集群中由master统一处理写请求,集群中服务器的个数必须满足n/2+1,否则服务不可用
- 满足CAP中的基于CP的Consul-基于raft共识算法来保证数据的强一致性,与zk类似集群中由master统一写请求,集群中服务器的个数必须满足n/2+1,否则服务不可用
- 既可以满足CAP中CP也可以使用AP的阿里新一代注册中心Nacos-其中CP也是通过raft算法实现,AP是通过自研的Distro算法实现。
基础准备
首先我们基于的springcloud的最新版本-Hoxton来介绍,这里使用的是springboot2.2.5,关于springboot与springCloud的版本对应关系可以参考下表:
| SpirngCloud Version | Boot Version |
|---|---|
| Hoxton |
2.2.x |
| Greenwich |
2.1.x |
| Finchley |
2.0.x |
| Edgware |
1.5.x |
| Dalston |
1.5.x |
1:Eureka
1 创建一个简单的Eureka注册中心
1.1 创建一个maven父工程
我们在通过maven搭建springcloud脚手架工程的第一件事情就是创建一个maven父工程, 如下所示:
<?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.fc.springCloud</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<!-- 定义引用类库版本 -->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-cloud.version>Hoxton.RELEASE</spring-cloud.version>
<java.version>1.8</java.version>
</properties>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<dependencies>
<!-- 引入公共jar -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<!-- 应用监控-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- 应用测试-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<!--引用springcloud对应版本-->
<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>
<modules>
<module>eureka</module>
<module>eurekaClient</module>
</modules>
</project>
1.2 创建Eureka注册中心
在上述的父工程中创建一个子model,命名为eurekaServer,用以构建注册中心
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>demo</artifactId>
<groupId>com.fc.springCloud</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>eureka-server</artifactId>
<packaging>jar</packaging>
<description>注册中心</description>
<dependencies>
<!-- SpringCloud Eureka 注册中心依赖 在不同版本此jar包是不同的 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!-- actuator监控-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
<build>
<finalName>eureka-center</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
yml配置文件(这里也可以使用properties,个人喜欢使用yml,比较层次分明),可参考后续详细配置,自行删减。
上述为一个基础配置项,对于包含的其他项配置,后续通过源码分析介绍。
java启动类:
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
/**
*
* 注册中心
* @author fangyuan
*
*/
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@EnableEurekaServer
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
最终通过http://loc

本文深入分析了SpringCloud Eureka作为注册中心的源码,探讨了Eureka如何保证服务的高可用性,包括自我保护机制。通过分析Eureka服务端与客户端的源码,阐述了EurekaServerBootstrap、InstanceRegistry、EurekaServerContext等关键组件的工作原理。此外,文章还指出了Eureka存在的服务发现延迟问题,分析了服务端与客户端缓存的影响,并给出了优化建议。
最低0.47元/天 解锁文章
756

被折叠的 条评论
为什么被折叠?



