中科大计网学习记录笔记(十一):CDN

2024-02-14 19:04

本文主要是介绍中科大计网学习记录笔记(十一):CDN,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

学习视频:中科大郑烇、杨坚全套《计算机网络(自顶向下方法 第7版,James F.Kurose,Keith W.Ross)》课程
该视频是B站非常著名的计网学习视频,但相信很多朋友和我一样在听完前面的部分发现信息量过大,有太多无法理解的地方,在我第一次点开的时候也有相同的感受,但经过了一段时间项目的学习,对计网有了更多的了解,所以我准备在这次学习的时候做一些记录并且加入一些我的理解,希望能够帮助到大家。
往期笔记可以看专栏中的内容😊😊😊

文章目录

      • 2.7 CDN
        • 2.7.1 视频流化服务
        • 2.7.2 多媒体流化服务:DASH
        • 2.7.3 CDN

2.7 CDN

💡 CDN(内容分发网络)是一种 分布式的网络架构,旨在 有效地交付互联网上的内容到最终用户。CDN通过将内容存储在全球各地的服务器上,并利用就近性原则,使用户能够从距离更近、性能更好的服务器获取所需的内容,从而提高内容传输的速度和可靠性。

2.7.1 视频流化服务

👉 视频播放可以说是杀手级的应用,因为它占用的带宽很大,同时需要服务的用户又非常多,所以设计这种应用需要解决这两个问题:

  • 并发问题
    因为带宽很大且用户量很多所以单个服务器显然是不可行的,需要分布式的架构
  • 异构性
    对于不同的设备,比如手机和电脑,要求的视频的分辨率是不同的,这就导致给不同的设备也许要传输不同的内容

💡 视频服务知识补充

  1. 视频:以固定速度显示的 图像 序列
  2. 空间冗余和时间冗余:因为视频资源较大,传输的时候可以利用图像内和图像间的冗余来降低编码的比特数目
    • 空间冗余: 空间冗余指的是在 同一时刻不同位置 的信号值之间的冗余关系。
    • 时间冗余: 时间冗余指的是在信号的 不同时间点 上存在的冗余关系。
  3. 视频的编码方式(CBR 和 VBR):
    • VBR(可变比特率):
      • 优点:VBR 可以根据视频内容的复杂度和运动情况动态调整比特率,从而在保持视频质量的前提下实现更高的压缩率
      • 缺点:VBR 编码算法通常更复杂,需要更多的计算资源。此外,在网络传输和存储时,由于比特率的变化,可能会导致难以预测的带宽需求或者存储空间占用。
    • CBR(恒定比特率):
      • 优点:CBR 提供了恒定的比特率,使得视频流的传输更加 稳定,适用于对带宽要求较为严格的场景,如实时直播、视频会议等。
      • 缺点:对于内容复杂度较高的视频,CBR 可能会导致过度分配比特率,浪费带宽,或者在内容复杂度较高时造成 视频质量损失
  4. 视频播放的缓冲:视频播放的缓冲是指在观看在线视频时,视频播放器会预先加载一段时间的视频数据到缓冲区中,以确保在播放过程中能够平滑地播放视频,避免因为网络波动或者服务器响应延迟而导致的视频卡顿或者停顿现象。这也就是为什么即使断网视频仍然可以持续一段时间的原因,因为缓冲区内仍有资源。
2.7.2 多媒体流化服务:DASH

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 DASH(Dynamic Adaptive Streaming over HTTP)是一种 流媒体传输协议,允许服务提供商根据客户端的网络情况和设备性能动态调整 视频流的质量和码率

👉 服务器端:将视频分割成多个 ,每个块独立的存储,编码与不同的码率,同时生成一个告示文件,告示文件中包含每个块的 URL 地址。

👉 客户端:先获取告示文件,周期性的测试自己与服务器之间的带宽,用于选择接收何种码率的文件;客户端查询告示文件,在一个时刻请求一个块,这个请求是自适应的,请求的时机会使得缓存不会溢出但是又不会不足以支持播放。

通过这种方式可以解决上面提到的异构的问题,但是对于高并发和高带宽占用的问题还需要解决,这就需要 CDN 来解决

👉 CDN 解决了如下的问题

  1. 服务端到客户端之间的跳数比较多
  2. 网络中相同的资源很多(比如不同的人再看相同的节目),导致传输资源的浪费
  3. 服务器引发的单点故障和性能瓶颈的问题
2.7.3 CDN

💡 CDN 为购买其服务的公司提供内容加速的服务,让内容更加靠近用户。

👉 CDN 服务的提供商会在全网部署缓存节点,存储服务内容,从而将服务分散开来,解决并发的问题,同时就近为用户提供低延迟的服务,CDN 提供商通常将缓存节点部署在以下两种地方:

  • enter deep:深入到 ISP 提供的接入网中,距离用户更近,但节点较多,管理困难
  • bring home:部署在少数(十个左右)的关键节点位置

客户端通过告示文件中的地址来请求资源,通过域名的重定向来使得客户端能够找到距离最近的节点来接收数据。

简单的 CDN 案例:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

👉 在用户的角度看:用户访问了网页,在网页中点击了链接,网页为其提供了视频播放服务

👉 实际的业务流程:

  • 用户点击了链接,浏览器调用 Local DNS 来解析 IP 地址

  • 定位到播放服务提供方的权威 DNS 服务器(负责管理特定域名区域信息的DNS服务器)

  • DNS 服务器通过重定向将请求定位到 CDN 的权威 DNS 服务器

  • CDN 的服务器再提供一个能够提供最优服务的 IP 地址给用户

  • 最终浏览器请求到这个 IP 地址。

这篇关于中科大计网学习记录笔记(十一):CDN的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio