写点什么

严选应用的云原生演进实践

  • 2020-12-29
  • 本文字数:3673 字

    阅读完需:约 12 分钟

严选应用的云原生演进实践

2019 年初,严选的服务数量已经近千,系统越来越庞大。为了能更好地支撑上业务的蓬勃发展,严选团队和网易轻舟团队开启了云原生平台的共建项目,以此拉开了严选应用云原生演进的帷幕。本文主要从严选的视角介绍一下相关的实践过程。


1. 背景


Cloud Native 这个名词最近几年一直很火,Pivotal 和 CNCF 都出过相关的定义,但本质都是为了引导应用在业务日益复杂多变的场景下可以更好地利用云基建,做到更加敏捷高效。2019 年初,严选的服务数量已经近千,系统越来越庞大。为了能更好地支撑上业务的蓬勃发展,严选团队和网易轻舟团队开启了云原生平台的共建项目,以此拉开了严选应用云原生演进的帷幕。本文主要从严选的视角介绍一下相关的实践过程。


对于严选来讲,将应用逐步演进到云原生的核心在于:“简化”,主要体现在以下三个方面:


  • 以服务网格的演进,实践中间件下沉到基础设施:简化应用内的非业务逻辑

  • 通过容器化,落地不可变基础设施:简化应用所处执行环境的搭建和维护

  • 实践基于云的 DevOps:简化应用在不同周期阶段内的流转复杂度


在整体演进中,我们主要从以下几个方面去考虑实施方案:


  • 标准化:一方面用于偿还部分历史遗留的技术债务;另一方面为不可变基础设施的落地做好铺垫。

  • 减少源码变更:降低迁移成本,保障业务正常迭代,同时也能减少由于迁移引入的 bug


  • 基础设施适配,业务弱感知完成迁移


  • 高可用的平滑迁移:为线上业务的可靠性保驾护航


  • 发布平台赋能业务迁移高可用:灰度引流、版本分流

  • 基于边缘网关的混合云方案:云内外自动兜底,实现业务逐步平滑迁移上云


  • 性能调优:面对由于服务网格,异地机房等带来的性能挑战


  • 引入 sr-iov 容器网络,降低 sidecar 转发带来的损耗

  • 突破 istio 原生性能瓶颈:利用遥测数据进行自动配置瘦身


2. 实践


应用演进的关键点基本都围绕着 Heroku 提出的 12-factor 展开,整体的演进节奏类似于建造一座大楼。



2.1 第一阶段


“打地基”:以严选 DevOps 项目作为主线,在异构的底层设施上构建近似的应用执行环境,弱化业务应用对基础设施的直接感知。


  • CMDB:从服务出发,管理人员、服务、资源三者之间的关系,使上层应用可以用统一的抽象概念看待云内和云外不同的底层资源和基础设施。(参见:《严选DevOps工具链的建设》

  • Opera:以制品为中心,在制品上贯彻云原生“不可变基础设施”的理念,同一制品贯穿测试、回归、线上等环境的全生命周期。同时统一部署流水线,统一发布依赖、发布流程、发布脚本的编排,为应用在云内、云外不同环境下的部署行为提供相同的功能和操作习惯,降低迁移时的学习成本。

  • 日志平台:提供了日志实时采集、分流、数据投递与存储的全流程能力,同时提供日志质量检查及查询分析能力,全面提升严选的数据质量与海量日志处理/分析能力,特别是对于容器环境下组件众多,依赖复杂的场景,一套高效的日志处理系统能为业务应用的日常监控、异常诊断带来必需的安全感。

  • ServiceMesh:实践中间件下沉的核心抓手。严选服务端原先有基于 consul+nginx 实现的简版服务网格,该架构无法与 k8s、docker 等云基础设施有效融合,因此在云内选用了 istio 作为实施标准。(参见:《架构不止-严选Service Mesh架构的持续演进》


2.2 第二阶段


“做框架”:在第一阶段的基础上,选择基础技术服务和部分 B 端业务应用作为落地的试点,完成服务容器化方案的框架指引。


  • 工程改造指引:包含基础镜像规范、CI 标准规范等,采用平台方式,逐步将这些规范收归到职能团队,避免不同研发团队的随意发挥。

  • 部署验证指引:包含资源、权限申请流程、灰度验证流程规范、回收流程等,确保流程依赖的正确性,并基于标准流程构建自动化流水线,从而达到效率提升的目标。

  • 流量管控(API 网关,参见:《严选网关架构演进之路》


  • 数据面:和轻舟协作,构建基于 envoy 的 API 网关,将原本严选 API 网关的一些能力以插件形式移植到了云原生网关中,保证了业务所需。

  • 控制面:改造原有严选的管理平台,适配轻舟 API,确保用户使用习惯尽可能保持一致,同时减少了严选内部其他依赖网关的管理系统的变更。


2.3 第三阶段


“建管道”:Backing Service 云化,服务治理能力深入,开始试点一些延迟敏感型的活动类业务应用改造。


  • Backing Service 云化


  • DB、缓存、MQ 这几个核心的 Backing Service 切换到云内,一方面降低异地机房带来的性能损耗,另一方面也能有更高效的扩缩容流程

  • 通过严选自研的中间件可以在应用不需要重启的情况下,将应用所依赖的这些支撑服务动态地从云外资源切换到云内资源。


  • 服务治理能力深化


  • Service Mesh 调优:


  • 实现热升级机制,避免 sidecar 更新时对业务应用的影响;

  • 增加灰度发布机制,降低网格更新时的风险;

  • 提供配置瘦身功能,降低大量节点场景下配置更新时的性能损耗。

  • 引入基于 sr-iov 容器网络的高性能节点


  • 强化 SNest 服务门户:将底层从定义、生命周期、版本、迁移、注册、监控、所有权等多个方面的服务治理能力层统一进行包装和暴露,提升日常使用时的效率。(参见:《在路上:严选服务治理实践》


  • C 端活动的上云试点,作为上述两个方向能力发展的验证落地,已经准备好应对双 11 大促的流量。


2.4 第四阶段


“搭房间”:开启线下环境的治理(该阶段和第三阶段会有部分重叠),由点到面地推进演进范围;扩大应用云化后的收益,例如:自动化地按需快速扩缩容。


  • 开发环境构建


  • 纯粹的云内环境,既能为基础设施提供测试验证环境,也方便业务应用尝试云原生的改造,并且资源灵活可控。


  • 回归环境构建


  • 完整模拟异地机房、云内云外异构基础设施的应用混布环境,提供接近线上的基础设施场景,为业务应用在大规模演进过程中保驾护航。

  • 作为严选环境治理的先锋任务,回归环境的构建在逐步试错和探索过程中前行。经历了量化目标、梳理落地方案、具体的规划集群、基建梳理、业务梳理、环境数据构造等各种环节,困难重重也获益良多。(参见:《严选线下环境治理之路-回归环境篇》


3. 一些“收获”


如影随形的“IP 地址”:应用中对 ip 的使用习惯几乎渗透到了每个服务,从最基本的远程调用,到简单又有效的鉴权场景,也有用于生成分布式 id 之类的。


  • 容器化时的第一步就是先引入 IPRange 机制,确保类似数据库这些当前还是强依赖 IP 鉴权的服务能正常运作。

  • 基于 IP 的服务调用方式,需要切换到根据域名或者依赖 service-mesh 机制的服务调用路由


  • 这方面严选由于很早就已经启用了服务网格的机制,因此改造代价不高,直接的 IP 地址主要集中在类似缓存,mq 之类自身有负载均衡策略的第三方组件。


  • 基于 IP 的服务鉴权场景,由于涉及到的服务众多,这块的改造成本是最大的。目前严选的做法是为每个服务颁发身份 Token,利用服务网格的 sidecar 进行注入,需要鉴权的服务从原本针对 ip 的逻辑改为针对 token 的逻辑。整个 token 的签发和注入对上层应用都是透明的,即减轻了改造成本,也能尽量避免 token 的泄露。

  • 其他基于 ip 地址构建分布式 id,任务分配等场景,就只能根据服务逻辑一一进行改造了,但这些涉及到的服务不多,整体改造成本可控。


系统整体的可观测性


  • 整个基础设施的复杂度提高了很多,不少环境对应用来讲变成黑盒了;一些以往登录虚拟机上进行诊断之类的习惯做法也无法沿用。

  • 最常见的服务之间调用有点小问题,也不得不喊上网关或者服务网格的同事协助排除。

  • 容器化后对于整个监控体系,异常诊断体系都是一场大考,很容易发现原本工具链中的盲点,不得不靠人肉先顶上。

  • 严选在实践中会和轻舟做数据打通:把关键组件的日志、关键报警、k8s 的重要事件等收纳到自身的监控体系内,从而丰富应用维度能感知到的信息。此外,正在和轻舟协作一起实践全链路故障的定位诊断服务。


对团队的影响


  • 业务开发:现阶段最大的可感知收益在于扩缩容的效率,云内可以做到秒级的资源变更,在大促、重要活动等场景下能够快速达成资源诉求。同时对基础设施整体工具链提出了更迫切的需求。

  • Infra 开发:在设计上需要更深入地分层,更多地思考采用非侵入式的实现,做好中间件的“下沉“ ,并解决下沉后带来的性能损耗。

  • QA:可以更灵活地调配资源用于线下环境治理,与运维配合保障各环境的一致性。同时负责在 CI/CD 流程中做好规范的落地,避免应用标准腐化。

  • 运维:对基础设施的管控能力有所提升,从而能够在资源管控的精细化和全面自动化方面有更为广阔的提升空间。


4. 后继计划


目前严选已累积上云 300+服务,每天支撑业务百亿次调用; CICD 接入率 99%以上,平均每天通过基于容器云的高可用的 gitlab runner 进行 ci pipeline 构建数千次,整体提升研发效能 200%+。


环境治理是当前的重点,我们会进一步完善回归环境,为后继性能敏感型应用的演进提供更全面的验证环境,同时将会尝试利用服务网格特性,构建基于服务版本的测试环境治理,提升数据共用场景下的业务集群快速构建效率。


对于严选应用来讲,云原生的演进之路才刚刚走离泥泞小路,前面的路会越来越宽,也会有更大的挑战,需要不断前行!



作者简介


Saga, 网易严选基础技术部技术总监,负责严选技术中后台建设,目前专注在业务中台、DevOps 等效能提升方向的体系搭建和发展。


头图:Unsplash

原文严选应用的云原生演进实践

来源:严选技术产品团队 - 微信公众号 [ID:YanxuanTechProd]

转载:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2020-12-29 23:251749

评论

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

AI加速测试流程:自动化测试脚本生成方案实现

测吧(北京)科技有限公司

测试

AI 辅助测试框架搭建:简化测试工作流

测吧(北京)科技有限公司

测试

聊聊PowerJob的CleanService

伤感汤姆布利柏

跨境云手机如何简化tiktok运营流程

Ogcloud

TikTok 云手机 海外云手机 Tik Tok直播 tiktok云手机

低代码开发:助力企业迈向智能化未来

EquatorCoco

低代码 数字化转型 企业转型

适用于 Amazon Step Functions 的低代码可视化新工作流 Workflow Studio, 现已在 Amazon Application Composer 正式发布!

亚马逊云科技 (Amazon Web Services)

低代码 亚马逊云科技 Amazon Lambda Amazon Step Functions

企业专属语言模型与知识图谱:定制化智能解决方案

测吧(北京)科技有限公司

测试

私有版语言模型开发:保障数据隐私与安全

测吧(北京)科技有限公司

测试

5分钟教你搭建chatgpt,结合midjourney上线即可运营

aiisai

ChatGPT MidJourney chatgpt app

从差旅申请到易快报,企业如何通过聚道云实现流程自动化?

聚道云软件连接器

案例分享

云手机受欢迎背后的原因及未来展望

Ogcloud

云手机 海外云手机 云手机海外版 国外云手机

云手机在引流方面有什么优势?

Ogcloud

云手机 海外云手机 云手机海外版 电商云手机

Vue框架与前端部署:构建现代化Web应用的利器

不在线第一只蜗牛

Vue 前端框架 web开发 Vue 3

精通C语言:打造高效便捷的通讯录管理系统

EquatorCoco

算法 C语言 通讯录

从人员外包到测试工具、测试平台,提供全方位的测试解决方案

测试人

外包 软件测试 测试工具 测试平台

基于Doris构建亿级数据实时数据分析系统

不在线第一只蜗牛

MySQL 数据库 Doris

AI自动生成测试用例思维导图

测吧(北京)科技有限公司

测试

AI自动化Bug发现:提升软件质量保障

测吧(北京)科技有限公司

测试

从人员外包到测试工具、测试平台,提供全方位的测试解决方案~

测吧(北京)科技有限公司

测试

The Captainz NFT 概览与数据分析

Footprint Analytics

NFT 数字藏品

高防云服务器租用常见问题解答:确保顺畅的租用体验

一只扑棱蛾子

高防服务器 高防云服务器

Python可视化工具集合来报道(上)

小齐写代码

WorkPlus AI助理提供智能化客服解决方案,助力企业高效沟通

WorkPlus

糟糕,接口被刷了,怎么办?

快乐非自愿限量之名

面试 接口 计算机

AI助力测试:高效批量生成测试数据方案实现

测吧(北京)科技有限公司

测试

Meta Llama 大模型:强大的 AI 能力支持

测吧(北京)科技有限公司

测试

SQL注入有什么办法防范

德迅云安全杨德俊

1 月比特币 ETF 终上市,公链稳健发展

Footprint Analytics

区块链 公链 BTC

WorkPlus Meet助力企业建立安全可靠的私有化视频会议平台

WorkPlus

个性化AI应用:定制专属学习助手

测吧(北京)科技有限公司

测试

严选应用的云原生演进实践_技术管理_严选技术产品团队_InfoQ精选文章