logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

Eureka

负责服务的注册与发现

采用C-S架构设计,EurekaServer作为服务注册功能的服务器,系统中的其他微服务使用Eureka客户端并维持心跳连接,这样可以通过EurekaServer监控各个微服务是否正常

三大角色

两大组件

服务端

导入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>

配置

server:
  port: 8000

# Eureka配置
eureka:
  instance:
    # 服务端实例名称
    hostname: localhost
  client:
    # 是否注册自己,默认true
    register-with-eureka: false
    # false表示自己为注册中心
    fetch-registry: false
    # 监控页码地址,动态配置
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka

开启服务

@SpringBootApplication
// 开启服务
@EnableEurekaServer
public class Eureka_8000 {
    public static void main(String[] args) {
        SpringApplication.run(Eureka_8000.class, args);
    }
}

访问localhost:8000即可看到监控页面

客户端

同理客户端配置,该客户端为提供服务者

添加依赖

<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka</artifactId>
    <version>1.4.7.RELEASE</version>
</dependency>

配置

# Eureka
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8000/eureka

开启服务:在主启动类上加@EnableEurekaClient

保护机制

当监控页面出现EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY'RE红色字样,是Eureka进入了保护模式,重启即可,稍等一下其他服务就会注册进来

某一个时刻微服务不可用了,Eureka不会立即清理,依旧会对该微服务的信息进行保存

默认情况下,如果EurekaServer在一定时间内没有接收到某个微服务的心跳,EurekaServer将会注销实例(90秒),但是当网络出现故障等情况导致EurekaServer无法与微服务正常通信,这时清除该服务就危险了,因为微服务本身是健康的,此时不应该注销这个服务。Eureka通过自我保护机制来解决这样的问题,当EurekaServer短时间内丢失过多客户端时,那么这个节点就会进入自我保护模式,将保护服务注册表中的信息,不再删除服务注册表中的数据(也就是不注销任何服务),当节点恢复后,EurekaServer会自动退出自我保护模式

该架构哲学为宁可同时保留所有微服务(健康和不健康的),也不盲目注销任何微服务

可以通过配置关闭,但不建议

集群

单台注册中的容错率太低了,一旦宕机,整个服务都会瘫痪,还是要集群部署

示例

# Eureka配置
eureka:
  instance:
    # 服务端实例名称,集群注意不要一样
    hostname: localhost
  client:
    # 是否注册自己,默认true
    register-with-eureka: false
    # false表示自己为注册中心
    fetch-registry: false
    # 监控页面地址
    service-url:
      # 单机可用,动态配置
      #defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
      # 集群配置,配置其他Eureka,相互绑定,多个用,分隔
      defaultZone: http://localhost:8000/eureka/

客户端连接多个

# Eureka
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8000/eureka,http://localhost:8000/eureka/

CAP原则

CAP原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾

注意:由于分区容错性在分布式系统中是必须要保证的,因此只能在一致性和可用性之间权衡

Eureka
服务端
客户端
保护机制
集群
示例
CAP原则