热门标签 | 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如何平滑上下线服务


推荐阅读
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
  • 2018年3月31日,CSDN、火星财经联合中关村区块链产业联盟等机构举办的2018区块链技术及应用峰会(BTA)核心分会场圆满举行。多位业内顶尖专家深入探讨了区块链的核心技术原理及其在实际业务中的应用。 ... [详细]
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社区 版权所有