本文共 5256 字,大约阅读时间需要 17 分钟。
近年来,云端业务体系不断发展壮大,企业的需求也主要呈现出两个方向,一方面不断增加的数据量要求云端能够实现流量监控和管理;另一方面也需要云端能够便捷的进行容量扩展和业务升级。在这种要求下,容器技术不断发展成熟,以 Kubernetes 为代表的新兴技术也开始在成为各家云服务提供商的必争之地。
但是最终云服务的使用者是开发者,云产品的成功与否有话语权的永远是真正的用户。当下云计算领域竞争激烈,容器服务层出不穷,那么究竟怎样的产品服务才能俘获开发者的心呢?
为了得到真实而又客观的答案,华为云联合 InfoQ 共同发起了一场开发者众测活动,共 12 名来自不同企业的开发者,针对华为云的容器服务进行了全面的测试,本文便是以 12 位参与者的测试报告为基础进行整合,力求客观展现华为云的容器技术特点,并为有容器业务需求的开发者提供技术要点。
综述:在完善中追求完美
在本次测试的环节里,共有 12 人参与了本次测试,而由于开发者们的资历、业务需求以及测试环境的不同,因此不同的测评用户得出了不同的结论。
从测试用户的反馈来看,华为云容器的优势在于:功能丰富,分类合理;容器的创建速度快;应用及系统监控指标全面;资源利用率高;拥有详细的事件日志;对 Kubernetes 底层改造有相当彻底的研究和实践;提升了应用的管理和运维能力;页面操作响应快;打造了以 CCE 为核心的大规模可维护性极高的云集群;可升缩性强,部署快,相比自建节省很多资源开销。
不过同样的产品中,测试用户也列出了一些可改进的点:页面上可以尝试折叠用户不是很关心的部分基础操作;部分有状态显示的页面刷新速度不够及时;希望错误信息能给出详细的、清晰易懂的错误提示;服务列表的页面跳转如果能开启新的标签体验更佳。
那么这些优缺点是如何得出的呢? 为了详细阐述华为云的技术特性,笔者将测试用例和实际应用场景相结合以具体进行分析。
以 spring Cloud 为例,构建一个应用软件系统,需要的技术架构大致如下
图片引用自网络
生产环境部署此套应用需要如下几点可靠的保障:
如果按照生产级别的标准完成上述内容,需要一定的运维经验和技术功底。自行安装软件需要合理配置各种参数,这绝非一日两日的研究可以做到的。那么华为云解决这些问题的方法是怎样的呢?在此次测试中笔者发现,华为云针对需求有不同的解决方案。
从测试结果来看,搭建一个以 Spring Cloud 为微服务框架的应用系统,通过使用华为云是可以做到生产级别的保障要求的。更进一步的话,可以借助 Istio 服务网格,放弃使用 Spring Cloud 微服务框架,在应用毫无感知的情况下搭建微服务架构。
那么具体到测试中,这些不同功能的表现情况到底如何呢?以下就是本次测试中测试者对华为云在不同环节表现的评价。
目前,云容器引擎可以提供高性能可扩展的容器服务,整合网络和存储能力,兼容了 K8S 和 Docker 的容器生态。可选 Istio 服务网络,用户也可自行选择安装插件。此次测试的目的是为了验证用户成功创建容器隧道网络虚拟机集群和无状态工作负载时的体验。
在这一案例场景下的解决方案:
测试感受:
CCE 集群创建指引清晰。在需要填写的内容旁边存在一个小问号,将鼠标悬停就可以看到解释信息。
CCE 的创建过程比较简单,不需要很多的专业知识,全程可视化;而原生的 K8S 安装需要配置各种参数,必须对 K8S 比较熟悉才行。
CCE 安装很快,各个参数配置好后,差不多 4 分钟左右集群就创建好了。
CCE 的可视化管理功能很全面,监控也很全面,出现问题基本上都可以在网页上处理掉,不需要面对各种配置文件,日志文件。下图为实例异常后的实例自动回复事件日志
小结:
云容器引擎 CCE 有按需收费和包周期两种收费模式提供给用户选择,适合固件投资有限的用户使用。其最适用于大规模使用 Docker 或者大规模集群治理的业务场景。CCE 同样适合那些有波峰访问的集群服务,其动态扩容可以轻松化解服务器资源紧张的问题。在运维方面,CCE 提供了丰富的运维监控页面,可以对集群,节点,工作负载进行实时监控。
Istio 服务网格区别于 Spring Cloud 和 Dubbo,其可以在应用无感知的情况下构建微服务系统框架。相比于 K8S 对容器的治理,Istio 网络可以做到更加细粒度的服务治理。Istio 服务网格的核心技术是将 sidecar 注入到应用服务中,使得 sidecar 可以代理应用服务的全部流量。然后通过对 sidecar 的管理和策略下发,从而构建了高度可伸缩、有弹性、安全且可便于监控的微服务架构系统。此次测试的目的是为了验证华为云创建 Istio 服务网格的虚拟机集群的体验。
对上述案例场景的解决方案:
测试感受:
小结:
使用 Istio 服务网络,可以轻松做到金丝雀发布,服务高可用,细粒度的请求监控。Istio 可以说是下一代微服务架构的发展方向。华为云已经支持 Istio 服务网络,已经为未来的微服务体系铺平了道路。Istio 服务网络可以将运维和管理功能彻底从业务代码中脱离,做到对应用服务的完全透明,比较适合那些不希望使用 Spring Cloud 等微服务框架的应用集群。
自动化部署面临的问题有如下几点:自动化脚本编写复杂,自动化脚本可阅读性差,脚本参数动态配置表现不佳,环境搭建复杂,资源配给复杂。那么华为云的 AOS 的是如何解决上述问题的呢?
华为云的服务主要有如下特点:
测试感受:
小结:
Dokcer 将应用和环境融为一体,使得应用获得了很强的可移植性。而 AOS 应用编排服务则是将整个集群和集群需要的所有组件融为一体,这其中包括数据库服务,负载均衡服务,网络,存储,节点,防火墙。如此复杂的融合仅需要在画板上简单的拖拽就可以实现。
工作负载即服务的抽象,如:微服务中把复杂的业务逻辑拆分成不同的微服务,每个微服务在华为云中都可以称为一个工作负载;同一个服务的多个实例属于同一个工作负载;数据库服务也是一个工作负载。工作负载分为无状态的工作负载和有状态的工作负载。无状态指的是,服务之间完全独立,提供完全相同的服务,不存在任何依赖关系。有状态值的是,服务之间有依赖关系,有相互调用的情况,有存储共享的情况。此次测试的目的是验证创建无状态工作负载时的体验。
对上述案例场景的解决方案:
测试感受:
本次测试亲历了华为虚拟化集群的两个用例,一个是在集群中建立无状态负荷,并做了实例镜像版本的柔性升级,即灰度测试,一个是在集群的跨虚机容器间网络性能测试及反亲和性测试,均取得了较满意的效果。
总的使用感觉对比之前的 K8S 使用感受感觉云容器的启动和故障恢复速度略慢。
自动恢复功能很好,当一个实例死掉后,能够迅速创建新的实例。下图为实例自动恢复事件日志:
小结:
工作负载是华为云对单个微服务应用集合的称呼。工作负载可以对单个微服务集合配置健康检查、部署策略、伸缩策略,访问方式等。在 AOS 应用编排服务中部署的堆栈也会出现在工作负载中。如此的设计也可以在华为云不同服务之间完成交互和配合。
从本次测试结果来看,结合 12 位测试者的测试报告可以看出,华为云的容器产品依旧保持了一贯风格风格,大胆的拥抱了云原生应用管理与部署,可以提供大规模应用综合治理服务。虽然在细节方面依然存在一些普遍性的不足,但是将复杂的资源分配、环境部署交给华为云来完成,能够为开发者提供更加高效的工作环境。
从华为云的定位来看,企业级 Kubernetes 容器集群的高可用性和安全性,得到了普遍认可;其多样化付费方式、性能稳定、管理便捷并且提供了一些技术模板,对于初级开发者非常友好,这将会有效降低中小型企业的容器管理难度。在与部分华为云的客户接触中,华为云的服务态度与对客户的重视程度也获得了不错的口碑。有测试者也在结果中提到:“华为云将 docker 和 Kubernetes 结合,提升了应用服务的可移植性,加强了应用服务的综合治理能力。”
而从市场来看,目前大多数的云服务产品在弹性扩容伸缩方面存在一定的不足,而华为云在此方面的稳定性属于市场上少有的。在与业务衔接时,华为云全面采用的 Kubernetes 技术可以在监控和管理方面帮助企业获得先机。
作为云服务直接用户的你,对于云服务的刚需是什么?你有什么想对华为云说的吗?欢迎在评论区留言告诉我们,为了答谢大家对华为云的支持,截止本周四下午 5 点前,评论点赞最高的五位用户将获赠华为荣耀手环 3 一个(支持 NFC 支付、50 米防水,兼容 iOS\u0026amp; 安卓)!
与此同时,你还可以点击访问,获取一箩筐的福利,我要是你会多薅点羊毛屯着过冬。
转载地址:http://otizo.baihongyu.com/