写点什么

迁移至 Kubernetes 的三种主要方式对比

  • 2019-02-12
  • 本文字数:1432 字

    阅读完需:约 5 分钟

迁移至Kubernetes的三种主要方式对比

企业大规模迁移到云端的时间已经到了,对于正在使用的应用程序,应该如何打包呢?


如今,越来越多的企业选择将应用程序或 Web 服务迁移到云端,各大厂商提供的云基础架构不仅功能强大、稳定且更具扩展性。通过迁移到云,企业可以显著降低运营压力和成本。目前比较流行的选择是迁移到基于容器的云环境,Kubernetes 是最常用的方法。从长远来看,Kubernetes 最具扩展性,本文介绍了主要的三种迁移至 Kubernetes 的方法。

为何选择 Kubernetes?

在了解可迁移到 Kubernetes 的最佳实践和方法之前,值得花时间了解为什么 Kubernetes 是企业的最佳选择。对于初学者来说,Kubernetes 在设置云环境时提供了最大灵活性。


Kubernetes 有两个主要部分:主集群和充当服务容器的节点,这两个元素可以提供更好的可用性和可靠性。当节点处理应用程序的特定任务和部分时,主集群会处理诸如网络管理和其他资源之类的事情。


两部分设置意味着可以对节点进行更改,而不会影响整体集群。例如,当需要更新特定服务时,可以创建新节点并进行更新,然后告诉主集群使用新节点而不是旧节点即可。从迁移到 Kubernetes 的那一刻起,该方法可以最大限度减少停机时间。


此外,Kubernetes 非常灵活,对于如何相对于彼此建立节点没有严格规则。只要主集群配置为正确使用节点,应用程序或 Web 服务将顺利运行。

迁移策略:三个计划

重新托管(Rehosting)

目前,主要通过三种方式将应用迁移到 Kubernetes。第一种方式是重新托管(Rehosting),这也是所有方法中最简单的一种,基本是将整个 Web 服务或应用程序转移到 Kubernetes 集群。这意味着,只需将 Docker 包装在应用程序周围,然后配置 Kube YAML 文件进行部署即可。这个过程不涉及对应用程序进行更改,这也是转移到 Kubernetes 最快的方法。


但是,重新托管可能不是利用 Kubernetes 提供的云环境最有效(或高效)方式,此方式无法立即受益于 Kubernetes 的所有灵活性,但是很好的第一步。一旦初始迁移完成,就可以继续将服务和部分应用分解到其他节点。

重新平台化(Replatforming)

重新平台化是迁移到 Kubernetes 的第二种方法,可以准备应用程序并对其运行方式进行基本更改,而不是将整个应用程序移动到当前状态,这通常涉及将服务分解为单个容器和节点,并将不同功能分解成单独容器。


重新平台化比重新托管需要更多时间,这是因为将应用程序调整到基于容器的云环境并不是一个简单的过程。在本地 Kubernetes 集群和 Minikube 的帮助下,该过程可以变得更简单。


当处理分区版本以进行迁移时,应用程序可以继续运行。完成更新并布置服务集群后,迁移到 GKE 或 Azure 等云集群会变得更加容易,甚至可以在 Minikube 内部进行彻底测试,以确保更顺畅的过渡。

重构

重构是迁移到 Kubernetes 的主要方法之一。与前两种方法不同,整个应用程序和支持服务都经过修改,以更好地适应新分区环境。


在大多数情况下,重构涉及重新架构整个应用程序以充分利用云环境。例如,开发者可以使用与 Kubernetes 一起的云原生框架(例如 Knative)来重构服务,这可以在云中运行无服务器工作负载。


作为权衡,迁移过程需要更长时间并消耗更多资源。但是,在流程结束时,企业将拥有一个完全可扩展的应用程序,可充分利用 Kubernetes 提供的所有优势。如果需要了解代码库以支持主要版本升级,倾向于推荐此过程。


至于哪种方法最合适,答案取决于迁移目标,要迁移到云的应用程序以及当前配置应用程序的方式。


参考链接:


https://dzone.com/articles/cloud-migration-best-practices-how-to-move-your-pr


2019-02-12 10:424821
用户头像
赵钰莹 极客邦科技 总编辑

发布了 884 篇内容, 共 651.2 次阅读, 收获喜欢 2680 次。

关注

评论

发布
暂无评论
发现更多内容

太强了!阿里人用138个案例讲明白了Spring全家桶+Docker+MQ

做梦都在改BUG

Java spring 微服务 Spring Cloud Spring Boot

叹服!阿里自述SpringCloud微服务:入门+实战+案例

做梦都在改BUG

Java 架构 微服务 Spring Cloud

八股MQ002——说说Rebalance?

Codyida

后端

升级企业数智化底座 用友iuap拉满长期主义

用友BIP

硬核!阿里自爆虐心万字面试手册,Github上获赞89.7K

做梦都在改BUG

Java 程序员

小红书如何应对万亿级社交网络关系挑战?图存储系统 REDtao 来了!

小红书技术REDtech

云原生 存储 图数据库 跨云多活

八股MQ005——聊聊Broker

Codyida

后端

openEuler之上的K3s ARM64集群管理

openEuler

Linux 云原生 k8s AWS Kubernetes Serverless

153个!PCB板上的字母符号都代表啥?一图带你搞懂!

华秋PCB

物理 电路 元器件 PCB PCB设计

chatGPT是割韭菜的镰刀还是创业的新风口? | 社区征文

迷彩

AIGC 生成式人工智能 三周年征文 三周年连更

Spring Security 中的基本认证过滤器链

Java架构历程

Java spring security 三周年连更

全球首个开发者村“开村”!数字之光在何处点亮?

白洞计划

第四范式开源强化学习研究通用框架,支持单智能体、多智能体训练,还可训练自然语言任务!训练速度提升17%

Geek_32eb82

SpringBoot 项目解决跨域的几种方案

做梦都在改BUG

Java Spring Boot

Github高赞!Alibaba最新亿级并发系统架构(2023 版全彩小册)

Java你猿哥

Java 架构 分布式 高并发 架构设计

从0到100:小区物业报修小程序开发笔记

CC同学

面试官:如何保证 RabbitMQ 的消息可靠性

做梦都在改BUG

Java 面试 RabbitMQ 消息队列 消息中间件

即时通讯技术文集(第14期):WebSocket精华文章合集 [共15篇]

JackJiang

网络编程 即时通讯 IM

NFTScan 推出「nftonchain」Telegram channel,实时推送链上 NFT 热点数据

NFT Research

NFT 智能推送 #Web3

SAPUI5 本地工程中的键值对 sapux - true 的作用

汪子熙

前端开发 SAP Fiori SAP UI5 三周年连更

病假单|病假条|体检报告|诊断证明书|病历证明|医院化验单|ct报告|b超单|怀孕检查

病假条病假单

OceanBase 4.0(小鱼)入选2023数字中国建设峰会“十大硬核科技”!

OceanBase 数据库

数据库 oceanbase

简洁好用的思维导图软件:simplemind 中文版

真大的脸盆

Mac 思维导图 Mac 软件 思维导图软件

GPIO实验-主芯片GPIO输出实验

鸿蒙之旅

OpenHarmony 三周年连更

八股MQ001——为什么需要使用MQ?

Codyida

后端

八股MQ004——聊聊Producer

Codyida

后端

实战解读:隐钥科技数据库加密解决方案及场景化解析

Lily

SpringBoot自动配置原理详解

做梦都在改BUG

Java Spring Boot

膜拜!阿里人用10W字面经把Java面试官拿下了

做梦都在改BUG

Java java面试 Java八股文 Java面试题 Java面试八股文

面试被Spring Cloud拿捏?莫慌,阿里人用五个模块讲明白了SpringCloud微服务架构

做梦都在改BUG

Java 架构 微服务 Spring Cloud

干货满满的技术盛宴!OpenHarmony开发者大会技术分论坛成功举办

最新动态

迁移至Kubernetes的三种主要方式对比_服务革新_赵钰莹_InfoQ精选文章