1- 哪一种更适合用于流媒体视频?TCP 或 UDP 套接字以及为什么?

2-直播时,音频和视频分别来自服务器,那么如何确保我显示的视频和设备上播放的音频同步?

有帮助吗?

解决方案

我不久前编写了一个语音聊天应用程序,TCP 是不可能的,如果您正在寻找近实时数据流,UDP 多播实际上是唯一的方法。不过,通过 UDP 进行流传输有两个主要问题:

  1. 丢弃的数据包. 。就音频而言,这是一个非常简单的修复。通常,丢弃的数据包不会产生明显的差异(数据包是单独解压缩的)。然而,在处理视频时,特别是在视频被压缩的情况下(通常是这样),找出一个适当的传输协议来确保网络的稳健性至少可以说是一项艰巨的任务,特别是如果您是从头开始这样做的话。视频帧被分成不同的数据包。弄清楚当这些数据包丢失时该怎么办是很困难的。
  2. 音频和视频之间的同步. 。这是一个非常棘手的问题,我建议阅读 RTSP(实时流协议)等协议。这不是一件容易的事,但这里有一些介绍性信息: http://www.cs.columbia.edu/~hgs/rtsp/ - 有时它是通过发送单独的同步数据包(某些协议通过 TCP 发送这些数据包)来完成的,告诉播放器声音应如何与视频匹配。

其他提示

我会做UDP。但是这取决于你想要什么。 UDP丢弃报文,而不是等待(TCP)。权衡的是你是否希望有一个稳定的,但有时缓慢而昂贵的,或一个是有效的,但有时可能无法递送。是你的选择,当涉及到你想如何实现它,你如何使用它。

今天,即使YouTube的流通过HTTP ...这里是一个应用程序的NodeJS哪些流文件浏览器客户端...使用为出发点与音频很好地同步

现场直播视频
// usage 
// do following on server side (your laptop running nodejs)
// node this_file.js
//
// then once above is running point your browser at
//    http://localhost:8888
//
// of course your browser could be on your mobile or own custom app



var http = require('http'),
    fs = require('fs'),
    util = require('util');

var path = "/path/to/audio/or/video/file/local/to/server/cool.mp4"; // put any audio or video file here

var port = 8888;
var host = "localhost";

http.createServer(function (req, res) {

  var stat = fs.statSync(path);
  var total = stat.size;

  if (req.headers.range) {   // meaning client (browser) has moved the forward/back slider
                                         // which has sent this request back to this server logic ... cool
    var range = req.headers.range;
    var parts = range.replace(/bytes=/, "").split("-");
    var partialstart = parts[0];
    var partialend = parts[1];

    var start = parseInt(partialstart, 10);
    var end = partialend ? parseInt(partialend, 10) : total-1;
    var chunksize = (end-start)+1;
    console.log('RANGE: ' + start + ' - ' + end + ' = ' + chunksize);

    var file = fs.createReadStream(path, {start: start, end: end});
    res.writeHead(206, { 'Content-Range': 'bytes ' + start + '-' + end + '/' + total, 'Accept-Ranges': 'bytes', 'Content-Length': chunksize, 'Content-Type': 'video/mp4' });
    file.pipe(res);

  } else {

    console.log('ALL: ' + total);
    res.writeHead(200, { 'Content-Length': total, 'Content-Type': 'video/mp4' });
    fs.createReadStream(path).pipe(res);
  }
}).listen(port, host);

console.log("Server running at http://" + host + ":" + port + "/");
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top