Livepeer is a live video streaming network protocol that is fully decentralized, highly scalable, crypto token incentivized, and results in a solution which is cheaper to an app developer or broadcaster than using traditional centralized live video solutions. go-livepeer is a golang implementation of the protocol.
Building and running this node allows you to:
- Create a local Livepeer Network, or join the existing Livepeer test network.
- Broadcast a live stream into the network.
- Request that your stream be transcoded into multiple formats.
- Consume a live stream from the network.
For full documentation and a project overview, go to Livepeer Documentation or Livepeer Wiki
The easiest way to install Livepeer is by downloading the livepeer
and livepeer_cli
executables from the release page on Github.
- Download the packages for your OS - darwin for Macs and linux for linux.
- Untar them and optionally move the executables to your PATH.
You can also build the executables from scratch.
-
If you have never set up your Go programming environment, do so according to Go's Getting Started Guide.
-
You can fetch and build the
livepeer
binaries in one step by runninggo get github.com/livepeer/go-livepeer/cmd/livepeer
in terminal. The binaries should be built and put in $GOPATH/bin. -
If you already have the code, you can simply run
go build ./cmd/livepeer/livepeer.go
from the project root directory. To get latest version,git pull
from the project root directory.
The current version of Livepeer requires ffmpeg.
Please get ffmpeg
from the ffmpeg-static repo, install it to your PATH and make sure it can be invoked by the Livepeer node.
-
Make sure you have successfully gone through the steps in 'Installing Livepeer' and 'Additional Dependencies'.
-
Run
./livepeer -testnet
. -
Run
./livepeer_cli
.- You should see a wizard launch in the command line.
- The wizard should print out
Account Eth Addr
,Token balance
, andEth balance
-
Get some test eth from the eth faucet from http://eth-testnet.livepeer.org/. Make sure to use the Eth account address from above. Remember to add 0x as a prefix to address, if not present.
- You can check that the request is successful by going to
livepeer_cli
and selectingGet node status
. You should see a positiveEth balance
.
- You can check that the request is successful by going to
-
Now get some test Livepeer tokens. Pick
Get test Livepeer Token
.- You can check that the request is successful by going to
livepeer_cli
and selectingGet node status
. You should see yourToken balance
go up.
- You can check that the request is successful by going to
-
You should have some test Eth and test Livepeer tokens now. If that's the case, you are ready to broadcast.
To broadcast, run ./livepeer_cli
and pick 'Broadcast Video'.
- You should see your webcam becoming active and a manifestID printed on the screen.
Sometimes you want to use third-party broadcasting software, especially if you are running the software on Windows or Linux. Livepeer can take any RTMP stream as input, so you can use other popular streaming software to create the video stream. We recommend OBS or ffmpeg.
By default, the RTMP port is 1935. For example, if you are using OSX with ffmpeg, run
ffmpeg -f avfoundation -framerate 30 -pixel_format uyvy422 -i "0:0" -vcodec libx264 -tune zerolatency -b 1000k -x264-params keyint=60:min-keyint=60 -acodec aac -ac 1 -b:a 96k -f flv rtmp://localhost:1935/movie
Similarly, you can use OBS, and change the setting->stream->URL to rtmp://localhost:1935/movie
If the broadcast is successful, you should be able to get a streamID by querying the local node:
curl http://localhost:8935/manifestID
To see the video, run ./livepeer_cli
and pick 'Stream Video'.
- You should see a video stream broadcasted from your webcam. It may feel a little delayed - that's normal. Video live streaming typically has latency from 15 seconds to a few minutes. We are working on solutions to lower this latency, using techniques like WebRTC, peer-to-peer streaming, and crypto-incentives.
Sometimes the stream tool doesn't work. You can use tools like ffplay
to view the stream.
For example, after you get the streamID, you can view the stream by running:
ffplay http://localhost:8935/stream/{manifestID}.m3u8
We'll walk through the steps of becoming a transcoder on the test network. To learn more about the transcoder, refer to the Livepeer whitepaper
-
livepeer --testnet --transcoder
to start the node as a transcoder. -
livepeer_cli
- make sure you have test ether and test Livepeer token. Refer to the Quick Start section for getting test ether and test tokens. -
You should see the Transcoder Status as "Not Registered".
-
Pick "Become a transcoder" in the wizard. Make sure to choose "bond to yourself". If Successful, you should see the Transcoder Status change to "Registered"
-
Wait for the next round to start, and your transcoder will become active.
Thank you for your interest in contributing to the core software of Livepeer.
There are many ways to contribute to the Livepeer community. To see the project overview, head to our Wiki overview page. The best way to get started is to reach out to us directly via our gitter channel.