如何获知Kubernetes是否适合您的SaaS云计算

来源:互联网 / 作者:SKY / 2018-03-12 15:15 / 点击:
Kubernetes是一项神奇的技术,我个人通过它在自己SaaS上实施扩展、部署和管理的过程已获益匪浅。但是客观而言,并非每个人都能够在采用它之后迅速获益的。

【Chinaz.com快译】Kubernetes是一项神奇的技术,我个人通过它在自己SaaS上实施扩展、部署和管理的过程已获益匪浅。但是客观而言,并非每个人都能够在采用它之后迅速获益的,一般有如下的原因:

对于容器技术熟悉程度的缺乏

应用架构不利于使用到Kubernetes的优势

增加的工作量和所花费的时间

因此,如果你对Kubernetes感兴趣,却又不确定是否值得投入必要的时间与资源的话,那么本文应该比较适合您来参考阅读。

一、您对容器是否有经验?

为了理解Kubernetes能够为您做些什么,您首先需要了解容器能够提供哪些优势。因此在你花时间开始使用Kubernetes之前,请事先准备如下几点:

1.容器化您的应用程序

如何获知Kubernetes是否适合您的SaaS

首先也是最重要的:您的应用程序必须已经实现了容器化。这意味着您已经定义好了相关的步骤来设定一个基本的OS映像,并且将您的应用程序打包成为一个文件(通常是一个Dockerfile)安装进去了。

通过上述过程、以及定义配置应用程序所需的环境变量(如应用程序所使用的数据库的URL、用户名和密码)都是至关重要的。这些能够保证您的容器映像对于Kubernetes来说是可用的。

同时,您还要记下应用程序所需运行时的各种依赖关系,并且理解如何去使用它们的容器版本。

2.理解存储是如何运作的

容器一般被设计为仅保存运行某个应用程序所需的代码。由于对容器进行卸载(tear down)和启动(spin up)的进程(在处理多个容器时,该现象十分常见)都会破坏存储在该容器文件系统中的所有数据,因此任何持久性数据都需要被存储到其他地方。

在考虑Kubernetes时,您应当去理解容器存储是如何被设定运作的,以及如何处理诸如备份数据、在容器之间移动数据、以及从容器外部访问数据等问题。

Kubernetes通过诸如自动资源调配的功能,使得存储管理更易于实现。该功能也使得您的存储提供商(如AWS EBS)在忙于创建新的容器时,会及时创建一些新的卷,并自动加载它们。

3.理解网络是如何运作的

您的网络构建方式会对您使用Kubernetes产生巨大的影响。对于新手来说,了解如何在做好隐藏部分信息的情况下,将特定的系统开放给外部互联网应用(如数据库),同时保持服务之间的通信是非常重要的。根据经验,我们需要掌握一些更为复杂的背景知识,包括:如何集成负载平衡,以及给每个客户的实例定义主机名等。这些都会使得Kubernetes的使用变得容易得多。

二、Kubernetes能够解决您当前面临的各种问题吗?

如何获知Kubernetes是否适合您的SaaS

如果您并没有使用容器来部署自己的应用,那么您可能就不需要用到Kubernetes了。因为Kubernetes所解决的问题,一般是你在试用和扩展一个基于容器的架构时所碰到的。

下面是我认为Kubernetes在试图解决容器扩展问题时,所能表现出的优势之处。

1.扩展资源

从本质上来说,Kubernetes是一组节点的集群,它提供了可由容器的工作负载所使用的计算资源。这种群集架构能够非常容易地对各种资源进行扩展或缩减。您只要在群集中添加或删除某些节点,Kubernetes就会自动利用这些资源,或者是对您现有资源进行工作负载上的重新分配。

该特性曾经解决了我所面临的一个棘手问题。因为我最初只有一台单独的服务器,为了能够持续扩展(这本来会是一个麻烦的手动过程),我只需要在CLI(命令行界面中)使用一条命令,就有能力对自己的架构进行自由缩放了。

2.执行大量的更新

Kubernetes的另一个能力是:它能够解决对所有容器的更新问题。过去,我不得不编写一些shell脚本来选择每个相关的容器,并使用新的镜像标签来重新创建它们。整个过程不但要持续一个多小时,而且我都无法去验证更新是否成功。如今,使用了Kubernetes,我就能通过如下的一条命令来执行更新操作:

// Update all the pods of frontend to a new image tage  

$ kubectl rolling-update frontend --image=image:v2 

Kubernetes还允许您基于任何标准、通过各种命令,来更新Kubernetes的任一部分(包括网络、存储等)。从编写自己的脚本来进行架构更改的角度来说,这是一项巨大的进步。

3.自愈功能

自愈功能是最后一个需要在此提及的,却又是Kubernetes最重要的能力。如果Kubernetes在其架构中检测到诸如:某个节点没响应了、或是某个容器未通过健康检查之类的问题出现时,它会根据既定的步骤执行重新创建相应涉及到的部分,一直到它们能够重新恢复运作为止。

这是非常有用的。如果群集中的某个部分因为某种原因而下线时,其对应的工作负载应当被重新分配,而且您甚至可以让Kubernetes重建整个服务器来解决问题。

三、您的应用程序架构是否需要更改?

如何获知Kubernetes是否适合您的SaaS


有时候,在您的应用上采用Kubernetes,就像将一个方木钉打入一个圆孔中。

由于我的应用最初就是被构建为:通过多个容器的部署,产生一个多实例的平台,因此当被迁移到Kubernetes时,我并没有做太多的更改。

下面我分享一些在把自己的工作负载迁移到Kubernetes的过程中所学到的内容。

1.应用的启动时间很重要

阅读延展

1
3