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
|
||||
|
||||
* HTTPS is not supported yet. It really should be.
|
||||
* There aren't any access controls on either the source or viewer roles yet.
|
||||
* 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. (see "Nginx Proxying" below, though)
|
||||
* 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 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)
|
||||
|
||||
## 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
|
||||
|
||||
* 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;
|
||||
|
||||
header! { (XAccelBuffering, "X-Accel-Buffering") => [String] }
|
||||
|
||||
const BUFFER_LIMIT: usize = 2 * 1024 * 1024;
|
||||
|
||||
type BodyStream = Box<Stream<Item = Chunk, Error = HyperError>>;
|
||||
|
@ -96,10 +98,12 @@ impl Service for RelayServer {
|
|||
(Head, "/live") => {
|
||||
Response::new()
|
||||
.with_header(ContentType("video/webm".parse().unwrap()))
|
||||
.with_header(XAccelBuffering("no".to_string()))
|
||||
},
|
||||
(Get, "/live") => {
|
||||
Response::new()
|
||||
.with_header(ContentType("video/webm".parse().unwrap()))
|
||||
.with_header(XAccelBuffering("no".to_string()))
|
||||
.with_body(self.get_stream())
|
||||
},
|
||||
(Post, "/live") | (Put, "/live") => {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#[macro_use] extern crate clap;
|
||||
extern crate futures;
|
||||
extern crate hyper;
|
||||
#[macro_use] extern crate hyper;
|
||||
extern crate tokio;
|
||||
extern crate tokio_core;
|
||||
extern crate tokio_io;
|
||||
|
|
Loading…
Reference in a new issue