app直播源码“助力”直播架构,走上探索之路

2024-01-07 23:20

本文主要是介绍app直播源码“助力”直播架构,走上探索之路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对于直播 app的开发来讲,app直播源码是一个非常重要的存在。直播架构在开发过程中也是一件非常重要的事情,如果架构的设立不能从根本上解决问题或防止问题的发生,那么在前端app运行时就会出现一定的运行错误。接下来主要跟大家简单分享一下关于直播架构方面的内容。

1.直播架构的演进

1)CDN直播架构

目前最流行的直播架构就是 CDN直播架构,主播通过手机或电脑等设备,将自己的视频流上传到服务器,然后接入对应的CDN服务,通过CDN 进行网络分发,分发到各地的用户,然后所有的用户都可以看到主播的表演了。

2)实时互动直播架构

实时互动直播并不能使用 CDN方案,因为CDN方案的性质决定了延时达不到实时的需求。通常,实现实时互动的架构中,主播把自己的视频流上传到服务器,再通过这台服务器分发给其他用户,再次采用合适的传输协议,并且延时可以做到很小,从主播到服务器再到观众的延时,加上编解码和抖动的延时,可以将延时控制在几百毫秒以内。虽然这个结构很简单,大势有一个缺点就是没有考虑到覆盖不同地区和用户的问题。

3)分布式实时互动直播架构

主播的视频流在上传到接入服务器后,这个服务器会把这个视频流分发到我们所部署在世界各地的服务器,然后这些服务器可以接入本地的用户,再把视频传下去。在这个架构里,部署在世界各地的服务器,可以让用户快速就近地接入,整个视频流通过我们在互联网上做的分布式传输算法将它实时传输到世界各地的机房,而且可以避免机房或者骨干性网络的故障,从而对传输造成一定的影响。

2. 解决覆盖问题

需要先部署大量边缘服务器,边缘服务器的地理位置越接近用户约越好,最好是同一个 SP。在这里举个简单的例子,比如在中国国内,我们有的是大量的电信、联通和移动服务器,当我们发现接入的用户是联通用户,这时候就会去找到联通的线路,但是如果有边缘地区的用户观看直播,那么就必须部署很多边缘服务器。还需要有分配服务,如果部署了边缘服务器之后,用户还是没办法接入边缘服务器,所以就需要配套的算法,根据用户的SP,从而找到与其最为匹配的边缘服务器,进行接入分配。

3.DNS解析问题

目前的无线互联网,也就是我们常用的 WiFi已经非常普及。但是在使用WiFi时,会出现一个比有线宽带还严重的问题:DNS解析。在用户接入时,第一步就是通过域名解析到最近的服务器,但是做DNS解析式,无线网络的信号就会收到一定的影响,从而导致DNS解析失败,所以就需要优先使用解析,如果解析不到再用静态IP配置。

4.“骨干型”网络故障问题

“骨干型”的网络中,经常会出现问题,如果出现故障,可以通过路由的方式构建想用的应对方式。先连接到分配服务,分配服务会给出一批可接入的机房,如果接入机房坏了,就会立即切换到下一个可用机房,如果切换到下一个机房发现还是坏的,就会再次接入分配服务,从而继续寻找当前可用的服务器。

5.  蜂拥

这是一种在实时互动直播过程中非常突出的一种现象,在短时间内大量的用户进入频道或者使用服务就可以称之为是蜂拥,对于后台的冲击力也十分巨大。大多数直播后台的服务器每秒接入大概千的量级,但是对于蜂拥而来的用户,处理量还远远不够。这时候通常就会出现一个问题就是,后台处理响应的速度越来越慢,很多用户的请求就会出现超时。超时之后就会进入更多的请求,导致整个后台系统不能响应。

      总而言之, app直播源码固然重要,但是在开发过程中,如果不注意直播架构方面的问题,那么在前端运行的过程中也会出现不少问题。毕竟对于直播app来说,最重要的还是用户的体验感受。

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


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69907981/viewspace-2565163/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/69907981/viewspace-2565163/

这篇关于app直播源码“助力”直播架构,走上探索之路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/581585

相关文章

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Spring 中 BeanFactoryPostProcessor 的作用和示例源码分析

《Spring中BeanFactoryPostProcessor的作用和示例源码分析》Spring的BeanFactoryPostProcessor是容器初始化的扩展接口,允许在Bean实例化前... 目录一、概览1. 核心定位2. 核心功能详解3. 关键特性二、Spring 内置的 BeanFactory

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

nginx-rtmp-module构建流媒体直播服务器实战指南

《nginx-rtmp-module构建流媒体直播服务器实战指南》本文主要介绍了nginx-rtmp-module构建流媒体直播服务器实战指南,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. RTMP协议介绍与应用RTMP协议的原理RTMP协议的应用RTMP与现代流媒体技术的关系2

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

macOS怎么轻松更换App图标? Mac电脑图标更换指南

《macOS怎么轻松更换App图标?Mac电脑图标更换指南》想要给你的Mac电脑按照自己的喜好来更换App图标?其实非常简单,只需要两步就能搞定,下面我来详细讲解一下... 虽然 MACOS 的个性化定制选项已经「缩水」,不如早期版本那么丰富,www.chinasem.cn但我们仍然可以按照自己的喜好来更换