导读:百度直播定位成直播SDK,赋能百度厂内APP使用,随着业务规模快速扩大、代码体量膨胀、宿主接入定制诉求强烈,在不影响业务迭代和业务规模扩张的前提下,直播工程架构也在不停优化。

全文2496字,预计阅读时间7分钟。

一、背景

百度直播定位成直播SDK, 赋能百度厂内APP使用, 随着业务规模快速扩大、代码体量膨胀, 直播原有工程结构限制了直播的快速发展, 随着垂类APP数量接入, 宿主接入流程中定制困难/配置调试耗时/需要实现的协议多等问题制约了SDK对外的输出, 总结起来就是以下两个大类问题:

  • 工程层面问题: 原生工程结构影响开发效率/业务代码耦合严重/宿主绑定的功能宏定义造成SDK差异化输出困难

  • 接入流程层面问题: 定制困难/配置调试耗时/协议众多等问题

在不影响业务迭代和业务规模扩张的前提下, 直播团团队有针对性的逐步进行了改造, 实现最终SDK灵活高效的平台化输出。

二、工程层面改造

工程层面改造分为三步走, 首先是工程接入EasyBox, 其次是业务维度组件化多仓库拆分, 在前两步基础上最后完善SDK差异化输出能力, 整体完成了工程架构改造迁移。

1.工程改造

直播最早期工程是基于Xcode原生工程, 多project嵌套连编实现工程构件, 这种方式在弊端太多, 基于手百自研EasyBox工具链, 直播进行了工程化的改造, EasyBox工具链对于工程是标准化的模版式改造

首先是对于liveBoxAPP工程的壳化, 其次对于原有的业务工程标准分层, 直播工程重新划分了逻辑层级:

  • 壳工程, 直播SDK编译运行构建环境

  • MixTure构建层, 控制SDK差异化构建,通过EasyBox支持变体(variant)组件的实现差异化, 通过link_dependency控制产物SDK的自由组合生成

  • 业务层, 直播核心业务

  • 基础库层

  • 宿主平台库依赖层/三方依赖库

基于以上改造, 使直播工程依赖关系更加清晰, Easybox分层使层级之间的依赖不会裂化, 以上改造只是基于直播原用工程结构的升级改造, 业务仓库本身还是有问题, 因此针对业务仓库做了多仓多组件模版拆分。

2.多仓多组件模版拆分

业务仓库的问题主要是业务耦合严重/权限无隔离, 直播早期仓库管理机制是Monorepo, 随着业务规模膨胀, 团队扩大, 直播按照模版业务唯独拆分了多仓库, 仓库管理升级到Multirepo, easyBox本身也支持Multirepo模式. 直播间业务VC是由一套slotPage框架来管理布局和服务, slotPage简单来说就是把直播间的UI和能力划分为(直播间内)组件/插件/服务, 提供组件的布局管理/事件分发/基础状态管理的一套页面管理机制, 直播针对business层仓库组件进行了模版维度的拆分, 具体分为已下几步:

  • Business层拆分出service层, 将通用能力统一下沉到service层仓库组件

  • 拆分基础核心直播容器组件, 提供直播间核心能力

  • 拆分直播间功能沉淀为通用组件插件池

  • 按照模版维度拆分Business层仓库组件, 归属业务模版特有的(直播间内)组件/插件

3. 支持SDK差异化输出

不同宿主对SDK定制需求差异化很大, 因此SDK要灵活支持裁剪, EasyBox虽然能通过变体(variant)和link_dependency能实现差异化构建, 但是对于直播间内小组件功能裁剪定制不太适用, ,因此直播提供小组件编译时注入能力, 直播组件都包含一个注册module, module分发直播核心的Module Event, 在event合适的时机, 注册组件的服务到Pyramid, 采用实现impl和interface分离的方式来实现真正的需要差异化输出组件的编译隔离, 差异化组件横向禁止依赖, impl组件只能依赖interface的接口组件。

基于以上改造, 灵活实现了直播功能小组件的差异化组装构建。

三、接入效率优化

工程层面问题改造完成后, 为了实现能够宿主自动接入/快速调试, 直播团队也做了很多辅助工具, 能够实现业务方自动化接入。

1. 自动化接入平台

由于SDK功能复杂而且可选,上下游依赖众多, 每接入一个宿主涉及众多业务,造成接入成本特别高, 因此直播开发了可视化出包平台, 宿主接入在用接入文档+自主出包平台的方案, 降低接入成本, 以下是流程图:

在接入平台上, 申请SDK接入, 填写相应的信息, 根据直播提供的功能清单选择功能, 审核通过后, 会触发对应的SDK构建, 可以快速获取SDK产物, 根据直播提供的接入文档, 即可实现自动接入。

2.快速源码调试/映射

直播是一个超大工程, 在宿主源码调试按照EasyBox配置方式需要引入直播所有仓库, 配置繁琐且容易出编译问题, 基于EasyBox工具, 直播开发了直播自己的源码调试插件, 可以在支持一键配置直播源码调试到宿主, 并且为了方便调试问题, 扩展了插件能力, 在EasyBox二进制源码映射机制开发了直播自己的小组件力度的映射, 原理图如下:

3.接入协议优化

SDK快速迭代, 对外暴露的协议也比较多, 每个宿主情况各异,每一个协议都实现对于业务接入成本也是很高, 直播提供一系列小组件二进制, 提供通用实现协议实现, 宿主根据自身情况自由引入, 降低接入成本。

四、收益

基于以上几步的改造, 收益比较明显, 主要是效率的提升:

  • 借助EasyBox和mgit , 工程复杂度降低, 直播业务同学开发成本降低

  • 基于直播差异化构建方案设计,垂类产品功能定制无需侵入直播核心业务,实现灵活可定制, 功能组件自由裁剪

  • 借助于自动接入平台, 大大降低沟通对接成本, 实现接入使用SDK的自动化,标准化

  • 开发EasyBox源码调试插件, 方便对接同学快速调试

五、结语

直播工程化是站在厂内EasyBox工具链的基础上, 结合直播特定的诉求, 演化成直播自己的工程开发模式, 无论是工程化改造还是接入效率优化,回归本质, 最终目的就是提升开发效率, 助力产品快速迭。

——————————END————————————

推荐阅读:

百度APP 基于Pipeline as Code的持续集成实践

Go 语言使用 MySQL 的常见故障分析和应对方法

百度交易中台之钱包系统架构浅析

基于宽表的数据建模应用

百度评论中台的设计与探索

基于模板配置的数据可视化平台

如何正确的评测视频画质

百度直播iOS SDK平台化输出改造相关推荐

  1. ios 点生成线路 百度地图_百度地图iOS SDK

    iOS SDK v2.3.0 百度地图 iOS SDK是一套基于iOS4.3及以上版本设备的应用程序接口,不仅提供展示地图的基本接口,还提供POI检索.路径规划.地图标注.离线地图.定位等丰富的LBS ...

  2. 来自锐动天地的直播ios SDK

    直播 iOS SDK,可以在手机iOS端实时采集视频,同时在拍摄过程中支持多种实时滤镜效果,只要调用视频直播接口,通过3G.4G.WIFI等网络,推流发送给云端流媒体直播系统处理,并通过CDN视频加速 ...

  3. 百度APP iOS端内存优化实践-大块内存监控方案

    ‍ 01 背景 ‍内存不足引发的APP崩溃通常称为OOM(Out Of Memory),iOS端无法捕获OOM异常,也得不到任何堆栈信息,给我们排查和解决问题带来很多困扰.引起OOM的原因归根结底就是 ...

  4. ios 点生成线路 百度地图_iOS SDK | 百度地图API SDK

    注意事项 1.静态库中采用ObjectC++实现,因此需要您保证您工程中至少有一个.mm后缀的源文件(您可以将任意一个.m后缀的文件改名为.mm),或者在工程属性中指定编译方式,即在Xcode的Pro ...

  5. 私藏干货分享:关于企业架构中如何进行平台化

    一.企业架构 企业信息架构这个词已经存在很多年, 从 1987 年的 Zachman Framework 开始到现在大概有 30 多年了. 企业架构(Enterprise Architecture), ...

  6. 私藏分享:关于企业架构中如何进行平台化

    备注:这一篇是来自在自己写的书某些章节删减,在这里并不对文章中所涉及到内容深入展开. 一.企业架构 企业信息架构这个词已经存在很多年, 从 1987 年的 Zachman Framework 开始到现 ...

  7. 公开课|百度天工物联网基础平台的微服务容器化落地实践

    本文整理自中信出版社<物联网时代> 在采用IoT的世界中,改变既是IoT引发的,也是你的生活中无法回避的事实. 弗洛伦斯·赫德森,是Internet2(Internet2,即I2,是指由美 ...

  8. 基于声网 iOS SDK 实现视频直播应用

    视频互动直播是当前比较热门的玩法,我们经常见到有PK 连麦.直播答题.一起 KTV.电商直播.互动大班课.视频相亲等.本文将演示如何通过声网视频 SDK 在 iOS 端实现一个视频直播应用.话不多说, ...

  9. 基于Swift利用百度lbs定位iOS SDK开发遇到的问题汇总

    在使用Swift语言,利用百度地图开放平台的iOS定位SDK进行开发时,可能会遇到一些小问题.基于一些笔者在开发过程遇到的问题,本文对问题进行了总结,并且给出了相应的解决方案供各位入门的开发者参考. ...

最新文章

  1. 机器视觉中如何选择工业相机与合适的相机镜头
  2. JavaScript Array 对象方法
  3. xlwt什么版本支持xlsx的版本_Spring Framework Versions版本支持说明
  4. Kubernetes包管理器Helm发布3.0版本
  5. 使用Spring跟踪应用程序异常
  6. java ppt转图片 内存溢出_Java虚拟机内存及内存溢出异常
  7. 棋盘问题(信息学奥赛一本通-T1217)
  8. linq 动态拼接where条件 类似 T_SQL And Or
  9. 解封装(五):AVStream和AVCodecParameters分析
  10. 视频编码中为什么须要进行变换编码?
  11. VC6.0打开或者添加工程文件崩溃的解决方法
  12. 傅里叶变换对应的matlab函数,用MATLAB如何实现傅里叶变换
  13. Hadoop技术之Hadoop HA 机制详解
  14. 抖音如何接入在线客服系统?
  15. 惠普暗影精灵键盘灯怎么开
  16. 小点评《实战SAP程序开发》-电子工业出版社 北京
  17. 数字图像处理第八章----图像压缩
  18. SAP MASS批量更新(Mass Maintenance)工具对象类型介绍
  19. android package service
  20. (20)-- 制作兄弟连首页

热门文章

  1. STM32HAL库定时器中断关闭的方法
  2. ctf-web-秋名山车神
  3. 图书管理系统1.0(当然是很简low的系统,没有华丽界面,但是很锻炼软件开发能力,只用到c++的面向对象知识)
  4. Redis删除大Key
  5. WINDOWS网络服务第一章预习导图
  6. 华为设备用户接入与认证配置命令
  7. Glide自定义缓存key
  8. 一著名软件公司的java笔试算法题的答案
  9. C语言编译出现give arg types警告问题
  10. 读 《人性的弱点》 有感