云原生应用——CDN场景下的自动化评测

云原生应用——CDN场景下的自动化评测

作者:朱玲 2022-11-24 13:43:40

云计算

云原生 云原生的核心是云原生应用。云原生架构是云原生应用的架构,云原生方法论是实现云原生应用的方法论,云原生体系就是构建、发布、运行云原生应用的理论、方法、工具、环境、流程、文化等等。CDN应用具备以下云原生特性:可以通过网络访问、远端部署执行、可扩展弹性伸缩、共享、按需使用自主服务、高可用、可远程监控计费升级、标准化交付与位置无关等,因此适用于云原生改造和迁移。

Part 01、什么是云原生下的CDN

CNCF对云原生(Cloud Native)的定义:

  • 云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。
  • 云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。
  • 这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。
  • 结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。

​CDN是广义边缘计算已落地的典型应用,通过边缘服务节点下沉,内容更贴近用户,有效改善业务感知。通过CDN的云化改造,释放边缘服务节点计算资源,提供容器管理技术为第三方应用落地边缘,提升资源利用率。

主要应用场景为三类:网页加速、下载加速、视音频点播/直播加速。

云原生CDN系统主要包括云化边缘节点以及边缘云平台和配套的云管平台。云管平台主要提供资源池管理、资源管理、辅助运营管理、流程管理、运维管理等功能,边缘云平台主要提供容器化部署环境,并可根据业务需求满足存储、网络、CPU、内存等资源的管理和分配。

Part 02、测试工具选型

云原生CDN测试的一大难点在于构建云原生测试场景难度高、测试时间长。阿里巴巴开源的Chaosblade–一个简单易用且功能强大的混沌实验实施工具,除了基础的CPU、disk、I/O、network外,还支持docker、dubbo、jvm的攻击,同时支持攻击后迅速回滚,是在k8s部署方式下最优方案,正好可以帮助我们构建丰富的云原生CDN的测试场景。

Chaosblade支持丰富的实验场景:

  • 基础资源:比如CPU、内存、网络、磁盘、进程等实验场景;
  • Java应用:比如数据库、缓存、消息、JVM本身、微服务等,还可以指定任意类方法注入各种复杂的实验场景;
  • C++应用:比如指定任意方法或某行代码注入延迟、变量和返回值篡改等实验场景;
  • Docker容器:比如杀容器、容器内CPU、内存、网络、磁盘、进程等实验场景;
  • 云原生平台:比如Kubernetes平台节点CPU、内存、网络、磁盘、进程实验场景,Pod网络和Pod本身实验场景如杀Pod,容器的实验场景如上述的Docker容器实验场景;

​针对云原生平台,chaosblade-operator遵循混沌实验模型规范化实验场景,把实验定义为Kubernetes CRD资源,将实验模型映射为Kubernetes资源属性,很友好的将混沌实验模型与Kubernetes声明式设计结合在一起,依靠混沌实验模型便捷开发场景的同时,又可以很好的结合Kubernetes设计理念,通过kubectl或者编写代码直接调用Kubernetes API来创建、更新、删除混沌实验,而且资源状态可以非常清晰的表示实验的执行状态,标准化实现Kubernetes故障注入。

综上所述,我们可以使用chaosblade-operator构建云原生CDN的测试场景,提高云原生CDN的测试效率。

Part 03、故障注入

评测云原生CDN平台的业务高可用和流量调度功能,需要在各类异常场景下验证业务访问的连续性与正确性。根据上文调研,我们使用chaosblade-operator混沌工具来实现异常场景的故障注入。具体使用方式如下:

1.下载安装chaosblade-operator

helm install --namespace kube-system --name chaosblade-operator chaosblade-operator-0.10.0-v2.tgz

根据上述命令,chaosblade-operator会被安装至kube-system命令空间下。chaosblade-operator启动后会在每个节点部署chaosblade-tool Pod和一个chaosblade-operator Pod。

2.查看安装结果

kubectl get pod -n kube-system -o wide | grep chaosblade

如果显示chaosblade-operator和chaosblade-tool Pod都处于Running状态,则说明部署成功。如果部署出现问题,可以查看chaoblade部署文档。

3.识别故障注入的类型、故障输入值、故障node名称、故障持续时间等参数。

故障类型包括:CPU、内存、磁盘、网络断开、节点挂掉。

4.根据识别的故障注入参数,执行故障注入命令(达到持续时间后自动销毁),如:

blade create k8s node-cpu fullload --names ${node节点名称} --cpu-percent ${故障输入值} --kubeconfig ~/.kube/config --timeout ${故障持续时间}

5.返回故障注入结果,故障注入成功

{"code":200,"success":true,"result":"beeaaf3a7007031d"}

Part 04、工具集成 

解决了云原生测试场景构建的难题,接下来就是将工具与云原生CDN业务结合,研发一套云原生CDN自动化测试平台,进一步提高测试效率。云原生CDN自动化测试平台的整体设计流程如下:

自动化的主要内容包括模拟业务访问、分析业务日志、故障注入。

  • 第一步:模拟业务访问,在云原生CDN节点生成业务日志;
  • 第二步:获取业务日志并进行分析,得到相关业务指标,如状态码、命中状态、节点IP等;
  • 第三步:使用chaosblade工具进行故障注入;
  • 第四步:继续模拟业务访问;
  • 第五步:获取并分析业务日志,将得到的业务指标与故障注入的指标进行对比分析,判断结果是否与预期相同,得到故障注入给业务带来的影响。

通过该云原生CDN自动化测试平台,我们可以有效地对CDN业务的调度、内容管理、分发安全等相关功能进行测评,降低测试难度,提高测试效率。最终的云原生CDN自动化测试平台界面如下:

Part 05、总结

结合混沌工程技术,我们可以快速地构建云原生的各类测试场景,降低云原生平台测试难度。该云原生CDN自动化测试平台已应用于日常版本与试点测试中,整体提升测试效率40%,保障了CDN业务虚拟化迁移的质量。目前,杭研vCDN能力已达到行业水平,基于vCDN的边缘能力已落地16个省份,承载家庭安防、VR、OTT等to H业务和现网to B、to N业务,服务用户数超千万。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/240882.html<

(0)
运维的头像运维
上一篇2025-04-24 02:08
下一篇 2025-04-24 02:10

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注