前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >网络直播开发过程中非常重要的一环

网络直播开发过程中非常重要的一环

原创
作者头像
肉2466131704
修改2019-03-04 17:07:04
4490
修改2019-03-04 17:07:04
举报
文章被收录于专栏:短视频开发短视频开发

相信大家对高并发这个词并不陌生,现在有很多家科技公司在进行人才招聘时都会问到关于高并发的问题。其实高并发通常指通过设计保证系统能够同时并行处理很多请求,是网络直播开发过程中关于系统架构必须考虑的因素之一。所以,在网络直播开发过程中,关于高并发的问题也是开发者们必须重视的一点。

图片来源于网络
图片来源于网络

1.怎样提升系统的并发能力

要想提高直播系统的并发能力,主要可以分为两种:垂直扩展与水平扩展。

(1)垂直扩展

即提升单机处理能力,垂直扩展的方式又分为两种。

l 增强单机硬件性能,比如增加CPU核数,扩充硬盘容量和系统内存。

l 提升单机架构性能,比如使用Cache来减少IO次数,使用异步来增加单服务吞吐量。

不足的是,单机性能总是有极限的,所以大部分高并发的解决方案还是会选用水平扩展,也就是我们下面要提到的。

(2)水平扩展

即只要增加服务器数量,就能线性扩充系统性能。水平扩展对于系统架构设计是有一定的要求的,关于如何在架构各层进行可水平扩展的设计,在此就不多做赘述了。

2. 常见的分层架构

(1)客户端层(2)反向代理层(3)站点应用层(4)服务层(5)数据-缓存层(6)数据-数据库层

图片来源于网络
图片来源于网络

3. 水平扩展在各分层中的实践

(1)反向代理层

反向代理层的水平扩展,是通过“DNS轮询”实现的,每次DNS解析请求来访问dns-server,会轮询返回这些ip。当nginx遭遇瓶颈时,只要增加服务器数量,新增nginx服务的部署,增加一个外网ip,就能扩展反向代理层的性能,做到理论上的无限高并发。

(2)站点层

是通过“nginx”实现的,通过修改nginx.conf,可以设置多个web后端。当web后端遭遇瓶颈时,只要增加服务器数量,新增web服务的部署,在nginx配置中配置上新的web后端,就能扩展站点层的性能,做到理论上的无限高并发。

(3)服务层

服务层的水平扩展,是通过“服务连接池”实现的。当服务遭遇瓶颈时,只要增加服务器数量,新增服务部署,在RPC-client处建立新的下游服务连接,就能扩展服务层性能,做到理论上的无限高并发。

(4)数据层

在数据量很大的情况下,数据层(缓存,数据库)涉及数据的水平扩展,将原本存储在一台服务器上的数据(缓存,数据库)水平拆分到不同服务器上去,以达到扩充系统性能的目的。

高并发是网络直播开发过程中经常遇到的问题,但并不能对其掉以轻心。对于直播行业来说,解决高并发也是核实开发实力的标准之一,再加上对实时效果要求甚严的直播应用场景,高并发可以说是“刻不容缓”的。

本文声明原创,转载请注明出处。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云直播
云直播(Cloud Streaming Services,CSS)为您提供极速、稳定、专业的云端直播处理服务,根据业务的不同直播场景需求,云直播提供了标准直播、快直播、云导播台三种服务,分别针对大规模实时观看、超低延时直播、便捷云端导播的场景,配合腾讯云视立方·直播 SDK,为您提供一站式的音视频直播解决方案。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档