Add X-Accel-Buffering header & Nginx proxying instructions
This commit is contained in:
parent
e1866a0918
commit
603e741753
3 changed files with 30 additions and 3 deletions
27
README.md
27
README.md
|
@ -40,13 +40,36 @@ You can use ffmpeg to transcode a non-WebM file or access a media device:
|
||||||
|
|
||||||
## Limitations
|
## Limitations
|
||||||
|
|
||||||
* HTTPS is not supported yet. It really should be.
|
* HTTPS is not supported yet. It really should be. (see "Nginx Proxying" below, though)
|
||||||
* There aren't any access controls on either the source or viewer roles yet.
|
* There aren't any access controls on either the source or viewer roles yet. (see "Nginx Proxying" below, though)
|
||||||
* Currently the server only recognizes a single stream, at `/live`.
|
* Currently the server only recognizes a single stream, at `/live`.
|
||||||
* The server tries to start a viewer at a cluster containing a keyframe; it is not yet smart enough to ensure that the keyframe belongs to the *video* stream.
|
* The server tries to start a viewer at a cluster containing a keyframe; it is not yet smart enough to ensure that the keyframe belongs to the *video* stream.
|
||||||
* The server doesn't parse any metadata, such as tags; the Info segment is stripped out, everything else is blindly passed along.
|
* The server doesn't parse any metadata, such as tags; the Info segment is stripped out, everything else is blindly passed along.
|
||||||
* The server drops any source that it feels uses too much buffer space. This is not yet configurable, though sane files probably won't hit the limit. (Essentially, clusters & the initialization segment can't individually be more than 2M)
|
* The server drops any source that it feels uses too much buffer space. This is not yet configurable, though sane files probably won't hit the limit. (Essentially, clusters & the initialization segment can't individually be more than 2M)
|
||||||
|
|
||||||
|
## Nginx Proxying
|
||||||
|
|
||||||
|
To get around the current lack of native HTTPS support, you can have nginx terminate the SSL connection; likewise you can have nginx handle access control.
|
||||||
|
|
||||||
|
The proxy block will need to include at least the following:
|
||||||
|
|
||||||
|
```nginx
|
||||||
|
location /webmetro/ {
|
||||||
|
# needed to stream PUT request bodies properly
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_request_buffering off;
|
||||||
|
client_max_body_size 0;
|
||||||
|
|
||||||
|
# alternatively you may wish to bar PUT requests so only local clients can transmit
|
||||||
|
# proxy_method GET;
|
||||||
|
|
||||||
|
# proxy to a relay server that's only listening on localhost
|
||||||
|
proxy_pass http://localhost:8080/;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
This is also useful to simply have the same public port shared by webmetro and a nicely-formatted viewer page.
|
||||||
|
|
||||||
## See Also
|
## See Also
|
||||||
|
|
||||||
* the [Icecast](http://www.icecast.org/) streaming server likewise relays media streams over HTTP, and supports additional non-WebM formats such as Ogg. It does not support clients connecting to a stream before the source, however.
|
* the [Icecast](http://www.icecast.org/) streaming server likewise relays media streams over HTTP, and supports additional non-WebM formats such as Ogg. It does not support clients connecting to a stream before the source, however.
|
||||||
|
|
|
@ -40,6 +40,8 @@ use webmetro::{
|
||||||
|
|
||||||
use super::to_hyper_error;
|
use super::to_hyper_error;
|
||||||
|
|
||||||
|
header! { (XAccelBuffering, "X-Accel-Buffering") => [String] }
|
||||||
|
|
||||||
const BUFFER_LIMIT: usize = 2 * 1024 * 1024;
|
const BUFFER_LIMIT: usize = 2 * 1024 * 1024;
|
||||||
|
|
||||||
type BodyStream = Box<Stream<Item = Chunk, Error = HyperError>>;
|
type BodyStream = Box<Stream<Item = Chunk, Error = HyperError>>;
|
||||||
|
@ -96,10 +98,12 @@ impl Service for RelayServer {
|
||||||
(Head, "/live") => {
|
(Head, "/live") => {
|
||||||
Response::new()
|
Response::new()
|
||||||
.with_header(ContentType("video/webm".parse().unwrap()))
|
.with_header(ContentType("video/webm".parse().unwrap()))
|
||||||
|
.with_header(XAccelBuffering("no".to_string()))
|
||||||
},
|
},
|
||||||
(Get, "/live") => {
|
(Get, "/live") => {
|
||||||
Response::new()
|
Response::new()
|
||||||
.with_header(ContentType("video/webm".parse().unwrap()))
|
.with_header(ContentType("video/webm".parse().unwrap()))
|
||||||
|
.with_header(XAccelBuffering("no".to_string()))
|
||||||
.with_body(self.get_stream())
|
.with_body(self.get_stream())
|
||||||
},
|
},
|
||||||
(Post, "/live") | (Put, "/live") => {
|
(Post, "/live") | (Put, "/live") => {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#[macro_use] extern crate clap;
|
#[macro_use] extern crate clap;
|
||||||
extern crate futures;
|
extern crate futures;
|
||||||
extern crate hyper;
|
#[macro_use] extern crate hyper;
|
||||||
extern crate tokio;
|
extern crate tokio;
|
||||||
extern crate tokio_core;
|
extern crate tokio_core;
|
||||||
extern crate tokio_io;
|
extern crate tokio_io;
|
||||||
|
|
Loading…
Reference in a new issue