README.md
Ultimate camera streaming application with support for dozens formats and protocols.
http://localhost:1984/Developers: integrate HTTP API into your smart home platform.
Download binary for your OS from latest release:
| name | description |
|---|---|
| go2rtc_win64.zip | Windows 10+ 64-bit |
| go2rtc_win32.zip | Windows 10+ 32-bit |
| go2rtc_win_arm64.zip | Windows ARM 64-bit |
| go2rtc_linux_amd64 | Linux 64-bit |
| go2rtc_linux_i386 | Linux 32-bit |
| go2rtc_linux_arm64 | Linux ARM 64-bit (ex. Raspberry 64-bit OS) |
| go2rtc_linux_arm | Linux ARM 32-bit (ex. Raspberry 32-bit OS) |
| go2rtc_linux_armv6 | Linux ARMv6 (for old Raspberry 1 and Zero) |
| go2rtc_linux_mipsel | Linux MIPS (ex. Xiaomi Gateway 3, Wyze cameras) |
| go2rtc_mac_amd64.zip | macOS 11+ Intel 64-bit |
| go2rtc_mac_arm64.zip | macOS ARM 64-bit |
| go2rtc_freebsd_amd64.zip | FreeBSD 64-bit |
| go2rtc_freebsd_arm64.zip | FreeBSD ARM 64-bit |
Don't forget to fix the rights chmod +x go2rtc_xxx_xxx on Linux and Mac.
PS. The application is compiled with the latest versions of the Go language for maximum speed and security. Therefore, the minimum OS versions depend on the Go language.
The Docker containers alexxit/go2rtc and ghcr.io/alexxit/go2rtc support multiple architectures including 386, amd64, arm/v6, arm/v7 and arm64.
These containers offer the same functionality as the Home Assistant add-on but are designed to operate independently of Home Assistant.
It comes preinstalled with FFmpeg and Python.
https://github.com/AlexxIT/hassio-addons
WebRTC Camera custom component can be used on any Home Assistant installation, including HassWP on Windows. It can automatically download and use the latest version of go2rtc. Or it can connect to an existing version of go2rtc. Addon installation in this case is optional.
Latest, but maybe unstable version:
alexxit/go2rtc:master or alexxit/go2rtc:master-hardware versionsgo2rtc master or go2rtc master hardware versionsThis is the go2rtc.yaml file in YAML-format.
The configuration can be changed in the WebUI at http://localhost:1984.
The editor provides syntax highlighting and checking.
The simplest config looks like this:
streams:
hall-camera: rtsp://admin:[email protected]/cam/realmonitor?channel=1&subtype=0
go2rtc.yaml in the current work directoryapi server will start on default 1984 port (TCP)rtsp server will start on default 8554 port (TCP)webrtc will use port 8555 (TCP/UDP) for connectionsMore information can be found here.
A summary table of all modules and features can be found here.
Core modules
app - Reading configs and setting up logs.api - Handle HTTP and WebSocket API.streams - Handle a list of streams.mpjpeg - The legacy but still used MJPEG protocol for real-time media transmission.onvif - A popular ONVIF protocol for receiving media in RTSP format.rtmp - The legacy but still used RTMP protocol for real-time media transmission.rtsp - The most common RTSP protocol for real-time media transmission.webrtc - WebRTC web-compatible protocol for real-time media transmission.yuv4mpegpipe - Raw YUV frame stream with YUV4MPEG header.bubble - Some NVR from dvr163.com and eseecloud.com.doorbird - Doorbird devices with two-way audio.dvrip - DVR-IP NVR, NetSurveillance, Sofia protocol (XMeye SDK).eseecloud - Some NVR from dvr163.com and eseecloud.com.gopro - GoPro cameras, connected via USB or Wi-Fi.hass - Import cameras from Home Assistant config files.homekit - Cameras with Apple HomeKit protocol.isapi - Two-way audio for Hikvision ISAPI protocol.kasa - TP-Link Kasa cameras.multitrans - Two-way audio for Chinese version of TP-Link cameras.nest - Google Nest cameras through user-unfriendly and paid APIs.ring - Ring cameras with two-way audio support.roborock - Roborock vacuums with cameras with two-way audio support.tapo - TP-Link Tapo cameras with two-way audio support.vigi - TP-Link Vigi cameras.tuya - Tuya ecosystem cameras with two-way audio support.webtorrent - Stream from another go2rtc via WebTorrent protocol.wyze - Wyze cameras using native P2P protocolxiaomi - Xiaomi Mi Home ecosystem cameras with two-way audio support.alsa - A framework for receiving audio from devices on Linux OS.v4l2 - A framework for receiving video from devices on Linux OS.adts - Audio stream in AAC codec with Audio Data Transport Stream headers.flv - The legacy but still used Flash Video format.h264 - AVC/H.264 bitstream.hevc - HEVC/H.265 bitstream.hls - A popular HTTP Live Streaming format.mjpeg - A continuous sequence of JPEG frames (without HTTP headers).mpegts - The legacy MPEG transport stream format.wav - Audio stream in Waveform Audio File format.echo - If the source has a dynamic link, you can use a bash or python script to get it.exec - You can run an external application (ffmpeg, gstreamer, rpicam, etc.) and receive a media stream from it.expr - If the source has a dynamic link, you can use Expr language to get it.ffmpeg - Use FFmpeg as a stream source. Hardware-accelerated transcoding and streaming from USB devices are supported.creality - Creality 3D printer cameras.kinesis - Amazon Kinesis video streams.openipc - Cameras on open-source OpenIPC firmware.switchbot - SwitchBot cameras.whep - WebRTC/WHEP is replaced by WebRTC/WISH standard for WebRTC video/audio viewers.wyze - Legacy method to connect to Wyze cameras via docker-wyze-bridge.adts - Output stream in ADTS format with AAC audio.ascii - Just for fun stream as ASCII to Terminal.flv - Output stream in Flash Video format.hls - Output stream in HTTP Live Streaming format.homekit - Output stream to Apple Home using HomeKit protocol.jpeg - Output snapshots in JPEG format.mpjpeg - Output a stream in MJPEG format.mp4 - Output as MP4 stream or Media Source Extensions (MSE) compatible format.mpegts - Output stream in MPEG transport stream format.onvif - Output stream using ONVIF protocol.rtmp - Output stream using Real-Time Messaging protocol.rtsp - Output stream using Real-Time Streaming protocol.webrtc - Output stream using Web Real-Time Communication API.webtorrent - Output stream using WebTorrent protocol.yuv4mpegpipe - Output in raw YUV frame stream with YUV4MPEG header.Supported for:
flv,
mjpeg,
mpegts,
rtmp,
rtsp,
webrtc.
This is a feature when go2rtc expects to receive an incoming stream from an external application. The stream transmission is started and stopped by an external application.
Supported for:
doorbird,
dvrip,
exec,
isapi,
multitrans,
ring,
roborock,
rtsp,
tapo,
tuya,
webrtc,
wyze,
xiaomi.
Two-way audio can be used in browser with WebRTC technology. The browser will give access to the microphone only for HTTPS sites (read more).
You can play audio files or live streams on any camera with two-way audio support.
You can publish any stream to streaming services (YouTube, Telegram, etc.) via RTMP/RTMPS.
You can preload any stream on go2rtc start. This is useful for cameras that take a long time to start up.
WebUI provides detailed information about all active connections, including IP-addresses, formats, protocols, number of packets and bytes transferred.
Via the HTTP API in json or dot format on an interactive connection map.
If you have questions about why video or audio is not displayed, you need to read the following sections.
| Name | FFmpeg | RTSP | Aliases |
|---|---|---|---|
| Advanced Audio Coding | aac | MPEG4-GENERIC | |
| Advanced Video Coding | h264 | H264 | AVC, H.264 |
| G.711 PCM (A-law) | alaw | PCMA | G711A |
| G.711 PCM (µ-law) | mulaw | PCMU | G711u |
| High Efficiency Video Coding | hevc | H265 | HEVC, H.265 |
| Motion JPEG | mpjpeg | JPEG | |
| MPEG-1 Audio Layer III | mp3 | MPA | |
| Opus Codec | opus | OPUS | |
| PCM signed 16-bit big-endian | s16be | L16 |
go2rtc can automatically detect which codecs your device supports for WebRTC and MSE technologies.
But it cannot be done for RTSP, HTTP progressive streaming, HLS technologies. You can manually add a codec filter when you create a link to a stream. The filters work the same for all three technologies. Filters do not create a new codec, they only select the suitable codec from existing sources. You can add new codecs to the stream using the FFmpeg transcoding.
Without filters:
Some examples:
rtsp://192.168.1.123:8554/camera1?mp4 - useful for recording as MP4 files (e.g. Home Assistant or Frigate)rtsp://192.168.1.123:8554/camera1?video=h264,h265&audio=aac - full version of the filter abovertsp://192.168.1.123:8554/camera1?video=h264&audio=aac&audio=opus - H264 video codec and two separate audio tracksrtsp://192.168.1.123:8554/camera1?video&audio=all - any video codec and all audio codecs as separate trackshttp://192.168.1.123:1984/api/stream.m3u8?src=camera1&mp4 - HLS stream with MP4 compatible codecs (HLS/fMP4)http://192.168.1.123:1984/api/stream.m3u8?src=camera1&mp4=flac - HLS stream with PCMA/PCMU/PCM audio support (HLS/fMP4), won't work on old deviceshttp://192.168.1.123:1984/api/stream.mp4?src=camera1&mp4=flac - MP4 file with PCMA/PCMU/PCM audio support, won't work on old devices (ex. iOS 12)http://192.168.1.123:1984/api/stream.mp4?src=camera1&mp4=all - MP4 file with non-standard audio codecs, won't work on some playersAVC/H.264 video can be played almost anywhere. But HEVC/H.265 has many limitations in supporting different devices and browsers.
| Device | WebRTC | MSE | HTTP* | HLS |
|---|---|---|---|---|
| latency | best | medium | bad | bad |
| Desktop Chrome 136+ | ||||
| Desktop Edge | ||||
| Android Chrome 136+ | H264, H265* | |||
| PCMU, PCMA | ||||
| OPUS | H264, H265* | |||
| AAC, FLAC* | ||||
| OPUS | H264, H265* | |||
| AAC, FLAC* | ||||
| OPUS, MP3 | no | |||
| Desktop Firefox | H264 | |||
| PCMU, PCMA | ||||
| OPUS | H264 | |||
| AAC, FLAC* | ||||
| OPUS | H264 | |||
| AAC, FLAC* | ||||
| OPUS | no | |||
| Desktop Safari 14+ | ||||
| iPad Safari 14+ | ||||
| iPhone Safari 17.1+ | H264, H265* | |||
| PCMU, PCMA | ||||
| OPUS | H264, H265 | |||
| AAC, FLAC* | no! | H264, H265 | ||
| AAC, FLAC* | ||||
| iPhone Safari 14+ | H264, H265* | |||
| PCMU, PCMA | ||||
| OPUS | no! | no! | H264, H265 | |
| AAC, FLAC* | ||||
| macOS Hass App | no | no | no | H264, H265 |
| AAC, FLAC* |
HTTP* - HTTP Progressive Streaming, not related to progressive download, because the file has no size and no endWebRTC H265 - supported in Chrome 136+, supported in Safari 18+MSE iPhone - supported in iOS 17.1+Audio
PCMA/PCMU/PCM codecs into FLAC for MSE/MP4/HLS so they'll work almost anywherePCMU/8000, PCMA/8000, OPUS/48000/2OPUS and MP3 inside MP4 are part of the standard, but some players do not support them anyway (especially Apple)Apple devices
There are no plans to embed complex transcoding algorithms inside go2rtc. FFmpeg source does a great job with this. Including hardware acceleration support.
But go2rtc has some simple algorithms. They are turned on automatically; you do not need to set them up additionally.
PCM for MSE/MP4/HLS
Go2rtc can pack PCMA, PCMU and PCM codecs into an MP4 container so that they work in all browsers and all built-in players on modern devices. Including Apple QuickTime:
PCMA/PCMU => PCM => FLAC => MSE/MP4/HLS
Resample PCMA/PCMU for WebRTC
By default WebRTC supports only PCMA/8000 and PCMU/8000. But go2rtc can automatically resample PCMA and PCMU codecs with a different sample rate. Also, go2rtc can transcode PCM codec to PCMA/8000, so WebRTC can play it:
PCM/xxx => PCMA/8000 => WebRTC
PCMA/xxx => PCMA/8000 => WebRTC
PCMU/xxx => PCMU/8000 => WebRTC
Important
For example, you want to watch an RTSP stream from a Dahua IPC-K42 camera in your Chrome browser.
H264 in camera settingsAAC/16000 in camera settingsOPUS/48000/2 codec, because it is higher quality than the PCMU/8000 or PCMA/8000Now you have a stream with two sources - RTSP and FFmpeg:
streams:
dahua:
- rtsp://admin:[email protected]/cam/realmonitor?channel=1&subtype=0&unicast=true&proto=Onvif
- ffmpeg:rtsp://admin:[email protected]/cam/realmonitor?channel=1&subtype=0#audio=opus
go2rtc automatically matches codecs for your browser across all of your stream sources. This is called multi-source two-way codec negotiation, and it's one of the main features of this app.
PS. You can select PCMU or PCMA codec in camera settings and not use transcoding at all. Or you can select AAC codec for main stream and PCMU codec for second stream and add both RTSP to YAML config, this also will work fine.
[!IMPORTANT] If an attacker gains access to the API, you are in danger. Through the API, an attacker can use insecure sources such as echo and exec. And get full access to your server.
For maximum (paranoid) security, go2rtc has special settings:
app:
# use only allowed modules
modules: [api, rtsp, webrtc, exec, ffmpeg, mjpeg]
api:
# use only allowed API paths
allow_paths: [/api, /api/streams, /api/webrtc, /api/frame.jpeg]
# enable auth for localhost (used together with username and password)
local_auth: true
exec:
# use only allowed exec paths
allow_paths: [ffmpeg]
By default, go2rtc starts the Web interface on port 1984 and RTSP on port 8554, as well as uses port 8555 for WebRTC connections. The three ports are accessible from your local network. So anyone on your local network can watch video from your cameras without authorization. The same rule applies to the Home Assistant add-on.
This is not a problem if you trust your local network as much as I do. But you can change this behaviour with a go2rtc.yaml config:
api:
listen: "127.0.0.1:1984" # localhost
rtsp:
listen: "127.0.0.1:8554" # localhost
webrtc:
listen: ":8555" # external TCP/UDP port
If you need web interface protection without the Home Assistant add-on, you need to use a reverse proxy, like Nginx, Caddy, etc.
PS. Additionally, WebRTC will try to use the 8555 UDP port to transmit encrypted media. It works without problems on the local network, and sometimes also works for external access, even if you haven't opened this port on your router (read more). But for stable external WebRTC access, you need to open the 8555 port on your router for both TCP and UDP.
Distributions
/live/ch00_1 in RTSP URL) - awful but usable RTSP protocol implementation, low stream quality, few settings, packet loss?Using apps for low RTSP delay
ffplay -fflags nobuffer -flags low_delay "rtsp://192.168.1.123:8554/camera1"Snapshots to Telegram