热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

k8s+springboot+Eureka如何平滑上下线服务

k8s+springboot+Eureka如何平滑上下线服务目录服务平滑上下线-k8s版本目录“上篇介绍了springboot+Euraka服务平滑上下线的方式,有部分小伙伴反馈k

k8s + spring boot + Eureka如何平滑上下线服务

  • 目录
    • 服务平滑上下线-k8s版本

目录

“ 上篇介绍了springboot+Euraka服务平滑上下线的方式,有部分小伙伴反馈k8s环境下有一些办法也可以解决这个平滑过度问题,为了解决这个问题,研究了一下目前我这边服务上k8s平滑过度的方案,分享给大家”

回顾:
回顾上文spring boot + Eureka如何平滑上下线服务,主要给大家介绍了两种服务平滑过度的版本:
单机方式:解决服务停止时,监听web容器是否还有未执行完的请求,等待其执行完才停止。
微服务方式:除了需要按单机方式增加web容器监听,还需要调整eureka client 、
ribbon、eureka server等三个地方的缓存参数,以保证其平滑过度。
本文主要介绍第三种,微服务部署在k8s上为例,看看如何解决服务平滑过度的问题。

服务平滑上下线-k8s版本

K8s介绍:

Kubernetes是Google开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。在生产环境中部署一个应用程序时,通常要部署该应用的多个实例以便对应用请求进行负载均衡。
在Kubernetes中,我们可以创建多个容器,每个容器里面运行一个应用实例,然后通过内置的负载均衡策略,实现对这一组应用实例的管理、发现、访问,而这些细节都不需要运维人员去进行复杂的手工配置和处理。
特点:
可移植: 支持公有云,私有云,混合云,多重云(multi-cloud)

可扩展: 模块化,插件化,可挂载,可组合

自动化: 自动部署,自动重启,自动复制,自动伸缩/扩展

注:上述介绍引用百度百科-https://baike.baidu.com/item/kubernetes/22864162?fr=aladdin

K8s部署方案:

从上述k8s的介绍就可以知道,k8s是一套可以灵活编排管理容器资源的工具,并且可以根据目前服务的请求压力动态的调整pod的数量来保证服务的稳定性和可用性,而且整个过程不需要人工干预,自动根据伸缩条件,进行管理。下面就给大家介绍一下k8s部署服务的流程,见下图:
k8s + spring boot + Eureka如何平滑上下线服务
从上图可以得知,k8s服务部署的流程是先启动一个新服务的pod,然后通过配置的服务检测方式,并行检测服务就绪以及存活的状态,只要其中一个条件满足就执行接下来的步骤,停止旧pod,停止旧的POD是并行的执行检测SLB下面是否有旧pod,如果有则删除该旧pod,并行调用eureka client服务下线的接口(具体接口,见上篇文章有源码),并行执行k8s停止前的钩子,执行休眠时间(这个时间为eureka服务整体缓存失效最大时间),接着执行旧pod下线,如果是linux系统会默认执行kill -15的命令,通知web应用停止(配置web容器下线前请求监听),最后pod删除,完成整个流程。

k8s服务平滑关键流程:
1、web应用需要增加eureka下线接口,供k8s调用使用

2、旧pod休眠时间参考eureka缓存失效最大时间

3、web应用增加容器监听,解决请求存在未处理完成,就被停止的问题

以上三点都是可以通过上一篇文章解决的。

liunx 命令解析:
kill -9 强制杀掉正在运行的程序,会导致正在请求的服务中断,且使web容器监听服务无法生效。
kill -15表示发送一个通知,告诉应用程序需要自己整成退出应用,退出前可以被堵塞或者回调处理,默认优雅停止程序可以使用该命令。

k8s + spring boot + Eureka如何平滑上下线服务


推荐阅读
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 本文详细介绍了 Kubernetes 集群管理工具 kubectl 的基本使用方法,涵盖了一系列常用的命令及其应用场景,旨在帮助初学者快速掌握 kubectl 的基本操作。 ... [详细]
  • 本文档详细介绍了在 Kubernetes 集群中部署 ETCD 数据库的过程,包括实验环境的准备、ETCD 证书的生成及配置、以及集群的启动与健康检查等关键步骤。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 本文介绍了如何在多线程环境中实现异步任务的事务控制,确保任务执行的一致性和可靠性。通过使用计数器和异常标记字段,系统能够准确判断所有异步线程的执行结果,并根据结果决定是否回滚或提交事务。 ... [详细]
  • Java项目分层架构设计与实践
    本文探讨了Java项目中应用分层的最佳实践,不仅介绍了常见的三层架构(Controller、Service、DAO),还深入分析了各层的职责划分及优化建议。通过合理的分层设计,可以提高代码的可维护性、扩展性和团队协作效率。 ... [详细]
author-avatar
小东东5201314
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有