mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-04 22:00:34 +08:00
119 lines
7.7 KiB
Markdown
119 lines
7.7 KiB
Markdown
|
[#]: subject: "Use your Raspberry Pi as a streaming server"
|
||
|
[#]: via: "https://opensource.com/article/23/3/raspberry-pi-streaming-server"
|
||
|
[#]: author: "Sven Erbeck https://opensource.com/users/erbeck"
|
||
|
[#]: collector: "lkxed"
|
||
|
[#]: translator: " "
|
||
|
[#]: reviewer: " "
|
||
|
[#]: publisher: " "
|
||
|
[#]: url: " "
|
||
|
|
||
|
Use your Raspberry Pi as a streaming server
|
||
|
======
|
||
|
|
||
|
There are various reasons to stream live video transmissions from webcams. The Raspberry Pi platform is perfect for such applications. It requires little power for continuous applications such as live-streaming servers. Communication with a Raspicam camera module, USB cam, or other network video signals is possible. The system is an RTMP, HLS, and SRT server. This article shows how to set up the Raspberry Pi as a streaming server to use HLS streaming. You need a video source to use it as a streaming server.
|
||
|
|
||
|
Even without a Raspberry Pi, you can do the steps described here. In addition, there are further installation instructions for [Windows][1], [Linux][2], and [macOS][3] available.
|
||
|
|
||
|
### Setup
|
||
|
|
||
|
The application is datarhei [Restreamer][4], a graphical user interface for the datarhei [Core][5]. The datarhei Core runs the well-known media framework FFmpeg under the hood. The easiest way to start with datarhei Restreamer is to install the official Docker container. The download and installation of the program via Docker Hub are automatic with the `pull` command. Restreamer starts immediately after the installation. If you don't have a Raspberry Pi, use one of the other Docker containers on the datarhei [Restreamer GitHub][4] page (e.g., AMD64 or GPU Cuda support).
|
||
|
|
||
|
datarhei Restreamer and datarhei Core are both open source software under the [Apache License 2.0][6].
|
||
|
|
||
|
Here's the command for an installation on a Raspberry Pi 3 and above with GPU support:
|
||
|
|
||
|
```
|
||
|
docker run -d --restart=always --name restreamer \
|
||
|
-v /opt/restreamer/config:/core/config -v /opt/restreamer/data:/core/data \
|
||
|
--privileged \
|
||
|
-p 8080:8080 -p 8181:8181 \
|
||
|
-p 1935:1935 -p 1936:1936 \
|
||
|
-p 6000:6000/udp \
|
||
|
datarhei/restreamer:rpi-latest
|
||
|
```
|
||
|
|
||
|
Regardless of which command you use, you only need the `--privileged` option to access local devices, like a USB camera.
|
||
|
|
||
|
After installation, connect the Raspberry Pi to the local network. Then open the web-based GUI in a browser by navigating to [http://device-ip:8181/ui][7].
|
||
|
|
||
|
You should see the following screen:
|
||
|
|
||
|
![First login into datarhei Restreamer][8]
|
||
|
|
||
|
Assign the password, and the system is ready for the first login. A wizard is starting to configure the first video source.
|
||
|
|
||
|
Hint: The above Docker command permanently stores the configuration data with the login name and password in the `/opt/restreamer/config` folder.
|
||
|
|
||
|
### Implementation
|
||
|
|
||
|
The application consists of three logical parts: Video input, system dashboard, and video output. The video input and output run independently of each other.
|
||
|
|
||
|
### Video input
|
||
|
|
||
|
The wizard will help you to create a video source right from the start. This can be a USB video source, the Raspberry Pi camera, or a network source like an IP cam or an m3u8 file from a network. HLS, RTMP, and real-time SRT protocol are ready to use. The wizard helps to configure the video resolution and sound correctly. In the last step, you can assign different licenses from Creative Commons. It is worth taking a look at the video signal settings. You will find several options, like transcoding or rotating the video for vertical video platforms.
|
||
|
|
||
|
### Dashboard
|
||
|
|
||
|
After successfully creating the video signal, you will land in the dashboard.
|
||
|
|
||
|
![datarhei Restreamer dashboard][9]
|
||
|
|
||
|
It is the central starting point for all other settings. To see the program's full functionality, you can switch to expert mode in system preferences.
|
||
|
|
||
|
The dashboard contains the following:
|
||
|
|
||
|
- Video signal settings.
|
||
|
- Active content URL for RTMP, SRT, HLS server, and snapshot.
|
||
|
- All active Publication Services for restreaming.
|
||
|
- Start the wizard to create additional video sources.
|
||
|
- The system menu.
|
||
|
- Live-Statistics for the video signal.
|
||
|
- Live-System monitoring.
|
||
|
|
||
|
### Video output
|
||
|
|
||
|
There are different ways to play the video signal.
|
||
|
|
||
|
The [publication website][10] is the simplest, immediately-ready, and internally hosted landing page by Restreamer. The player page can also transmit to Chromecast and AirPlay. Basic settings like adjusting the background image and adding a logo in the player are possible directly in the Restreamer. Those who know HTML can customize the page for themselves. Advanced users can inject code to use the site with external modules like a chat. A statistics module under the video player shows the active viewers and all views. The **Share** button supports the distribution of the live stream. HTTPS certificates for the website are active with Let's Encrypt without much effort. With a simple port forwarding for HTTPS to the LAN IP of the Raspberry Pi, the website is publicly accessible.
|
||
|
|
||
|
![Landingpage from datahrei Restreamer][11]
|
||
|
|
||
|
The publication services are a great way to restream content. There are numerous ready-made modules for popular websites like YouTube, Twitch, or PeerTube. Likewise, for other streaming software, to popular CDNs. Complete control over the video protocols allows streaming to all RTMP, HLS, and SRT-capable destination addresses. An HTML snippet code with the video player works on web pages.
|
||
|
|
||
|
![Presets for publication services][12]
|
||
|
|
||
|
### Save power while streaming with Raspberry Pi
|
||
|
|
||
|
This article shows how to turn the Raspberry Pi into a streaming server. The Raspberry Pi platform allows you to interact with various video signals in a power-saving way. The pre-settings make it easy to configure the server, and advanced users can make some adjustments to the system. You can use it for restreaming, hosting for live-streaming on a website, or integration into system landscapes with [OBS][13]. Using different video sources and transport protocols offer great flexibility as a basis for a project and make this system highly customizable. Furthermore, the datarhei Core with FFmpeg makes it easy for software developers to extend all application processes.
|
||
|
|
||
|
The program turns the Raspberry Pi into a dedicated streaming server. Depending on your internet upload, you can live stream to websites or multi-stream to different video networks independently and without an additional video provider.
|
||
|
|
||
|
Test a fully functional [demo][14] before installation on the project website with the login name **admin** and password **demo**.
|
||
|
|
||
|
--------------------------------------------------------------------------------
|
||
|
|
||
|
via: https://opensource.com/article/23/3/raspberry-pi-streaming-server
|
||
|
|
||
|
作者:[Sven Erbeck][a]
|
||
|
选题:[lkxed][b]
|
||
|
译者:[译者ID](https://github.com/译者ID)
|
||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||
|
|
||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
|
||
|
[a]: https://opensource.com/users/erbeck
|
||
|
[b]: https://github.com/lkxed/
|
||
|
[1]: https://docs.datarhei.com/restreamer/installing/windows
|
||
|
[2]: https://docs.datarhei.com/restreamer/installing/linux
|
||
|
[3]: https://docs.datarhei.com/restreamer/installing/mac
|
||
|
[4]: https://github.com/datarhei/restreamer
|
||
|
[5]: https://github.com/datarhei/core
|
||
|
[6]: https://github.com/datarhei/restreamer/blob/2.x/LICENSE
|
||
|
[7]: http://device-ip:8181/ui
|
||
|
[8]: https://opensource.com/sites/default/files/2023-01/fig2-first-login-datarhei.jpg
|
||
|
[9]: https://opensource.com/sites/default/files/2023-01/fig1-title-dashboard-datarhei.jpg
|
||
|
[10]: https://demo.datarhei.com/
|
||
|
[11]: https://opensource.com/sites/default/files/2023-01/fig3-int-publication-website-datarhei.jpg
|
||
|
[12]: https://opensource.com/sites/default/files/2023-01/fig4-preset-publication-services-datarhei.jpg
|
||
|
[13]: https://opensource.com/article/20/6/obs-websockets-streaming
|
||
|
[14]: https://demo.datarhei.com/ui
|