Skip to content

Latest commit

 

History

History
51 lines (36 loc) · 1.62 KB

README.md

File metadata and controls

51 lines (36 loc) · 1.62 KB

Video Streaming Server

Basic example of a video streaming service.

git clone [email protected]:krynv/video-streaming.git && npm i && npm start

The general gist of this

Browser -> Node JS server

Browser renders a basic HTML page with a <video src='/video' /> element.

The video element makes a request to the server on the /video endpoint.

Request Headers:

Request Headers {
    Request-URL: http://localhost:8000/video
    Request Method: GET
    Range: bytes=0-
}

To get the beginning of the video we need to request the 0'th byte; hence the 0-.

The server, in response, sends a part of the video (not the entire thing when you load the page), returning a 206 status code (partial content).

Response headers:

Response Headers {
    Accept_ranges: bytes
    Content-Length: 10000001
    Content-Range: bytes 0-1000000/63614462
    Content-Type: video/mp4
}

The webpage will recognise that this is an incomplete video, and the video element will only play what it has 'downloaded' so far.

As the video continues to play, the next 'chunk' is requested and the cycle continues...

Concluding thoughts

While a pretty simple implementation, taking literally 10 minutes to set up, this is not the best way to implement this.

Simple file stream & return back to the client. Small payloads, super fast for most users.

Scrubbing through the video does not however, save the content to the front end, or anywhere for that matter.

This means that we are essentially sending & receiving more data than the file content itself. A simple 64MB file can be 'streamed' to 100+ MB by just scrubbing through the video.