mirror of
https://github.com/ossrs/srs.git
synced 2025-02-15 04:42:04 +00:00
204 lines
15 KiB
Markdown
Executable file
204 lines
15 KiB
Markdown
Executable file
# SRS(Simple Realtime Server)
|
||
|
||
data:image/s3,"s3://crabby-images/0442c/0442c7580eac0f39ced86f3790f3f688bb35a89e" alt=""
|
||
[data:image/s3,"s3://crabby-images/4c8ba/4c8ba9166983a0564fca1d54a1a25ec793b6829b" alt=""](https://github.com/ossrs/srs/actions?query=workflow%3ACodeQL+branch%3Adevelop)
|
||
[data:image/s3,"s3://crabby-images/80fd4/80fd41c3d7a82a4a687f6843940bb31658e41b18" alt=""](https://github.com/ossrs/srs/actions/workflows/release.yml?query=workflow%3ARelease)
|
||
[data:image/s3,"s3://crabby-images/9a225/9a225eea78e790b7848862252ceb46a816ee8663" alt=""](https://github.com/ossrs/srs/actions?query=workflow%3ATest+branch%3Adevelop)
|
||
[data:image/s3,"s3://crabby-images/c1e9e/c1e9ec26ce0f06fbb720ac57652c71f8b615cecd" alt=""](https://codecov.io/gh/ossrs/srs/branch/develop)
|
||
[data:image/s3,"s3://crabby-images/cd307/cd307447a25fc532716db431043b074770b17e6b" alt=""](../../wikis/Contact#wechat)
|
||
[data:image/s3,"s3://crabby-images/0bf03/0bf03015bfb978b30364a04f064176b5f9893d87" alt=""](https://github.com/ossrs/srs/issues/2716)
|
||
[data:image/s3,"s3://crabby-images/f772b/f772b9cfb55eef86ab4bfa1e80ff60e1c88a138a" alt=""](http://mulanos.cn)
|
||
[data:image/s3,"s3://crabby-images/6e075/6e075771ddcd023d12d86beca4e2c164ff490b54" alt=""](https://alternativeto.net/software/srs/about/)
|
||
[data:image/s3,"s3://crabby-images/f54e1/f54e1a1e32d3f07975c01047bbffe671350b97e9" alt=""](https://www.youtube.com/channel/UCP6ZblCL_fIJoEyUzZxC1ng)
|
||
[data:image/s3,"s3://crabby-images/059c5/059c5940a5797d73ebdb9d0aaedf7f9e099c697e" alt=""](https://discord.gg/yZ4BnPmHAd)
|
||
[data:image/s3,"s3://crabby-images/a794c/a794ce96bf36e447dcf192e228c7c194f91b94e1" alt=""](https://opencollective.com/srs-server/contribute)
|
||
[data:image/s3,"s3://crabby-images/40de7/40de7aab347ce02733c6dfeb93c6bca22d244ac5" alt=""](https://stackoverflow.com/questions/tagged/simple-realtime-server)
|
||
[data:image/s3,"s3://crabby-images/b6d55/b6d5514065d3c572a8edeed4bf95f8e7c72769ca" alt=""](https://hub.docker.com/r/ossrs/srs/tags)
|
||
|
||
SRS/5.0,[Bee](https://github.com/ossrs/srs/wiki/Product#release50) 是一个简单高效的实时视频服务器,支持RTMP/WebRTC/HLS/HTTP-FLV/SRT。
|
||
|
||
SRS/5.0 is a simple, high efficiency and realtime video server, supports RTMP/WebRTC/HLS/HTTP-FLV/SRT.
|
||
|
||
SRS is licenced under [MIT](https://github.com/ossrs/srs/blob/develop/LICENSE) or [MulanPSL-2.0](https://spdx.org/licenses/MulanPSL-2.0.html),
|
||
and note that [MulanPSL-2.0 is compatible with Apache-2.0](https://www.apache.org/legal/resolved.html#category-a),
|
||
but some third-party libraries are distributed using their [own licenses](https://github.com/ossrs/srs/wiki/LicenseMixing).
|
||
|
||
[data:image/s3,"s3://crabby-images/7425b/7425bf9af8d0bb1bff6bb18fd8afbd2c25a8fae5" alt="SRS Overview"](https://ossrs.net/wiki/images/SRS-Overview-4.0.png)
|
||
|
||
> Note: If image load fail, please see it at [here](https://www.processon.com/view/link/619f29791efad425fd699fd2).
|
||
|
||
<a name="product"></a>
|
||
<a name="usage-docker"></a>
|
||
## Usage
|
||
|
||
Build SRS from source:
|
||
|
||
```
|
||
git clone -b develop https://gitee.com/ossrs/srs.git &&
|
||
cd srs/trunk && ./configure && make && ./objs/srs -c conf/srs.conf
|
||
```
|
||
|
||
Open [http://localhost:8080/](http://localhost:8080/) to check it, then publish
|
||
by [FFmpeg](https://ffmpeg.org/download.html) or [OBS](https://obsproject.com/download) as:
|
||
|
||
```bash
|
||
ffmpeg -re -i ./doc/source.flv -c copy -f flv -y rtmp://localhost/live/livestream
|
||
```
|
||
|
||
Play the following streams by [players](https://ossrs.net):
|
||
|
||
* RTMP (by [VLC](https://www.videolan.org/)): rtmp://localhost/live/livestream
|
||
* H5(HTTP-FLV): [http://localhost:8080/live/livestream.flv](http://localhost:8080/players/srs_player.html?autostart=true&stream=livestream.flv&port=8080&schema=http)
|
||
* H5(HLS): [http://localhost:8080/live/livestream.m3u8](http://localhost:8080/players/srs_player.html?autostart=true&stream=livestream.m3u8&port=8080&schema=http)
|
||
|
||
Note that if convert RTMP to WebRTC, please use [`rtmp2rtc.conf`](https://github.com/ossrs/srs/issues/2728#issuecomment-964686152):
|
||
|
||
* H5(WebRTC): [webrtc://localhost/live/livestream](http://localhost:8080/players/rtc_player.html?autostart=true)
|
||
|
||
> Note: Besides of FFmpeg or OBS, it's also able to [publish by H5](http://localhost:8080/players/rtc_publisher.html?autostart=true)
|
||
> if **WebRTC([CN](https://github.com/ossrs/srs/wiki/v4_CN_WebRTC#rtc-to-rtmp), [EN](https://github.com/ossrs/srs/wiki/v4_EN_WebRTC#rtc-to-rtmp))** is enabled,
|
||
> please remember to set the **CANDIDATE([CN](https://github.com/ossrs/srs/wiki/v4_CN_WebRTC#config-candidate) or [EN](https://github.com/ossrs/srs/wiki/v4_EN_WebRTC#config-candidate))** for WebRTC.
|
||
|
||
> Highly recommend that directly run SRS by
|
||
> **docker([CN](https://github.com/ossrs/srs/wiki/v4_CN_Home#docker) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_Home#docker))**,
|
||
> **Cloud Virtual Machine([CN](https://github.com/ossrs/srs/wiki/v4_CN_Home#cloud-virtual-machine) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_Home#cloud-virtual-machine))**,
|
||
> or **K8s([CN](https://github.com/ossrs/srs/wiki/v4_CN_Home#k8s) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_Home#k8s))**,
|
||
> however it's also easy to build SRS from source code, for detail please see
|
||
> **Getting Started([CN](https://github.com/ossrs/srs/wiki/v4_CN_Home#getting-started) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_Home#getting-started))**.
|
||
|
||
> Note: If need HTTPS, by which WebRTC and modern browsers require, please read
|
||
> **HTTPS API([CN](https://github.com/ossrs/srs/wiki/v4_CN_HTTPApi#https-api) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_HTTPApi#https-api))**
|
||
> and **HTTPS Callback([CN](https://github.com/ossrs/srs/wiki/v4_CN_HTTPCallback#https-callback) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_HTTPCallback#https-callback))**
|
||
> and **HTTPS Live Streaming([CN](https://github.com/ossrs/srs/wiki/v4_EN_DeliveryHttpStream#https-flv-live-stream) / [EN](https://github.com/ossrs/srs/wiki/v4_EN_DeliveryHttpStream#https-flv-live-stream))**,
|
||
> however HTTPS proxy also works perfect with SRS such as Nginx.
|
||
|
||
<a name="srs-40-wiki"></a>
|
||
<a name="wiki"></a>
|
||
|
||
From here, please read wikis:
|
||
|
||
* [Getting Started](https://github.com/ossrs/srs/wiki/v4_EN_Home#getting-started), please read Wiki first.
|
||
* [中文文档:起步](https://github.com/ossrs/srs/wiki/v4_CN_Home#getting-started),不读Wiki一定扑街,不读文档请不要提Issue,不读文档请不要提问题,任何文档中明确说过的疑问都不会解答。
|
||
|
||
Fast index for Wikis:
|
||
|
||
* Overview? ([CN](https://github.com/ossrs/srs/wiki/v4_CN_Home), [EN](https://github.com/ossrs/srs/wiki/v4_EN_Home))
|
||
* How to deliver RTMP streaming?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleRTMP), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleRTMP))
|
||
* How to build RTMP Edge-Cluster?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleRTMPCluster), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleRTMPCluster))
|
||
* How to build RTMP Origin-Cluster?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleOriginCluster), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleOriginCluster))
|
||
* How to deliver HTTP-FLV streaming?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleHttpFlv), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleHttpFlv))
|
||
* How to deliver HLS streaming?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleHLS), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleHLS))
|
||
* How to deliver low-latency streaming?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleRealtime), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleRealtime))
|
||
* How to use WebRTC? ([CN](https://github.com/ossrs/srs/wiki/v4_CN_WebRTC), [EN](https://github.com/ossrs/srs/wiki/v4_EN_WebRTC))
|
||
|
||
Other important wiki:
|
||
|
||
* Usage: How to delivery DASH(Experimental)?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleDASH), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleDASH))
|
||
* Usage: How to transode RTMP stream by FFMPEG?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleFFMPEG), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleFFMPEG))
|
||
* Usage: How to delivery HTTP FLV Live Streaming Cluster?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleHttpFlvCluster), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleHttpFlvCluster))
|
||
* Usage: How to ingest file/stream/device to RTMP?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleIngest), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleIngest))
|
||
* Usage: How to forward stream to other servers?([CN](https://github.com/ossrs/srs/wiki/v4_CN_SampleForward), [EN](https://github.com/ossrs/srs/wiki/v4_EN_SampleForward))
|
||
* Usage: How to improve edge performance for multiple CPUs? ([CN](https://github.com/ossrs/srs/wiki/v4_CN_REUSEPORT), [EN](https://github.com/ossrs/srs/wiki/v4_EN_REUSEPORT))
|
||
* Usage: How to file a bug or contact us? ([CN](https://github.com/ossrs/srs/wiki/v4_CN_Contact), [EN](https://github.com/ossrs/srs/wiki/v4_EN_Contact))
|
||
|
||
## AUTHORS
|
||
|
||
Thank you to all our contributors! 🙏
|
||
|
||
[data:image/s3,"s3://crabby-images/42384/42384d6febeb2aa1ff3ca6bbc4c970feec19f67a" alt=""](https://opencollective.com/srs-server/contribute)
|
||
|
||
> Note: You may provide financial support for this project by donating [via Open Collective](https://opencollective.com/srs-server/contribute). Thank you for your support!
|
||
|
||
The [TOC(Technical Oversight Committee)](trunk/AUTHORS.md#toc) and [contributors](trunk/AUTHORS.md#contributors):
|
||
|
||
* [Winlin](https://github.com/winlinvip): Focus on [ST](https://github.com/ossrs/state-threads) and [Issues/PR](https://github.com/ossrs/srs/issues).
|
||
* [ZhaoWenjie](https://github.com/wenjiegit): Focus on [HDS](https://github.com/simple-rtmp-server/srs/wiki/v4_CN_DeliveryHDS) and [Windows](https://github.com/ossrs/srs/issues/2532).
|
||
* [ShiWei](https://github.com/runner365): Focus on [SRT](https://github.com/simple-rtmp-server/srs/wiki/v4_CN_SRTWiki) and [H.265](https://github.com/ossrs/srs/issues/465).
|
||
* [XiaoZhihong](https://github.com/xiaozhihong): Focus on [WebRTC/QUIC](https://github.com/ossrs/srs/issues/2091) and [SRT](https://github.com/simple-rtmp-server/srs/wiki/v4_CN_SRTWiki).
|
||
* [WuPengqiang](https://github.com/Bepartofyou): Focus on [H.265](https://github.com/ossrs/srs/issues/465).
|
||
* [XiaLixin](https://github.com/xialixin): Focus on [GB28181](https://github.com/ossrs/srs/issues/1500).
|
||
* [LiPeng](https://github.com/lipeng19811218): Focus on [WebRTC](https://github.com/simple-rtmp-server/srs/wiki/v4_CN_WebRTC).
|
||
* [ChenGuanghua](https://github.com/chen-guanghua): Focus on [WebRTC/QoS](https://github.com/ossrs/srs/issues/2051).
|
||
* [ChenHaibo](https://github.com/duiniuluantanqin): Focus on [GB28181](https://github.com/ossrs/srs/issues/1500) and [API](https://github.com/ossrs/srs/issues/1657).
|
||
|
||
A big `THANK YOU` also goes to:
|
||
|
||
* All [contributors](trunk/AUTHORS.md#contributors) of SRS.
|
||
* All friends of SRS for [big supports](https://github.com/ossrs/srs/wiki/Product).
|
||
* [Genes](http://sourceforge.net/users/genes), [Mabbott](http://sourceforge.net/users/mabbott) and [Michael Talyanksy](https://github.com/michaeltalyansky) for creating and introducing [st](https://github.com/ossrs/state-threads/tree/srs).
|
||
|
||
## Contributing
|
||
|
||
We are grateful to the community for contributing bugfix and improvements, please follow the
|
||
[guide](https://github.com/ossrs/srs/contribute).
|
||
|
||
## Releases
|
||
|
||
* 2022-02-09, Release [v4.0-b7](https://github.com/ossrs/srs/releases/tag/v4.0-b7), v4.0-b7, 4.0 beta7, v4.0.240, 144437 lines.
|
||
* 2022-02-04, Release [v4.0-b6](https://github.com/ossrs/srs/releases/tag/v4.0-b6), v4.0-b6, 4.0 beta6, v4.0.238, 144437 lines.
|
||
* 2022-01-30, Release [v4.0-b5](https://github.com/ossrs/srs/releases/tag/v4.0-b5), v4.0-b5, 4.0 beta5, v4.0.236, 144416 lines.
|
||
* 2022-01-17, Release [v4.0-b4](https://github.com/ossrs/srs/releases/tag/v4.0-b4), v4.0-b4, 4.0 beta4, v4.0.230, 144393 lines.
|
||
* 2022-01-13, Release [v4.0-b3](https://github.com/ossrs/srs/releases/tag/v4.0-b3), v4.0-b3, 4.0 beta3, v4.0.229, 144393 lines.
|
||
* 2022-01-03, Release [v4.0-b2](https://github.com/ossrs/srs/releases/tag/v4.0-b2), v4.0-b2, 4.0 beta2, v4.0.215, 144278 lines.
|
||
* 2021-12-19, Release [v4.0-b1](https://github.com/ossrs/srs/releases/tag/v4.0-b1), v4.0-b1, 4.0 beta1, v4.0.206, 144126 lines.
|
||
* 2021-12-01, Release [v4.0-b0](https://github.com/ossrs/srs/releases/tag/v4.0-b0), v4.0-b0, 4.0 beta0, v4.0.201, 144022 lines.
|
||
* 2021-11-15, Release [v4.0.198](https://github.com/ossrs/srs/releases/tag/v4.0.198), 4.0 dev8, v4.0.198, 144010 lines.
|
||
* 2021-11-02, Release [v4.0.191](https://github.com/ossrs/srs/releases/tag/v4.0.191), 4.0 dev7, v4.0.191, 143890 lines.
|
||
* 2021-10-12, Release [v4.0.177](https://github.com/ossrs/srs/releases/tag/v4.0.177), 4.0 dev6, v4.0.177, 143686 lines.
|
||
* 2021-09-05, Release [v4.0.161](https://github.com/ossrs/srs/releases/tag/v4.0.161), 4.0 dev5, v4.0.161, 145865 lines.
|
||
* 2021-08-15, Release [v4.0.156](https://github.com/ossrs/srs/releases/tag/v4.0.156), 4.0 dev4, v4.0.156, 145490 lines.
|
||
* 2021-08-14, Release [v4.0.153](https://github.com/ossrs/srs/releases/tag/v4.0.153), 4.0 dev3, v4.0.153, 145506 lines.
|
||
* 2021-08-07, Release [v4.0.150](https://github.com/ossrs/srs/releases/tag/v4.0.150), 4.0 dev2, v4.0.150, 145289 lines.
|
||
* 2021-07-25, Release [v4.0.146](https://github.com/ossrs/srs/releases/tag/v4.0.146), 4.0 dev1, v4.0.146, 144026 lines.
|
||
* 2021-07-04, Release [v4.0.139](https://github.com/ossrs/srs/releases/tag/v4.0.139), 4.0 dev0, v4.0.139, 143245 lines.
|
||
* 2020-06-27, [Release v3.0-r0](https://github.com/ossrs/srs/releases/tag/v3.0-r0), 3.0 release0, 3.0.141, 122674 lines.
|
||
* 2020-02-02, [Release v3.0-b0](https://github.com/ossrs/srs/releases/tag/v3.0-b0), 3.0 beta0, 3.0.112, 121709 lines.
|
||
* 2019-10-04, [Release v3.0-a0](https://github.com/ossrs/srs/releases/tag/v3.0-a0), 3.0 alpha0, 3.0.56, 107946 lines.
|
||
* 2017-03-03, [Release v2.0-r0](https://github.com/ossrs/srs/releases/tag/v2.0-r0), 2.0 release0, 2.0.234, 86373 lines.
|
||
* 2016-08-06, [Release v2.0-b0](https://github.com/ossrs/srs/releases/tag/v2.0-b0), 2.0 beta0, 2.0.210, 89704 lines.
|
||
* 2015-08-23, [Release v2.0-a0](https://github.com/ossrs/srs/releases/tag/v2.0-a0), 2.0 alpha0, 2.0.185, 89022 lines.
|
||
* 2014-12-05, [Release v1.0-r0](https://github.com/ossrs/srs/releases/tag/v1.0-r0), all bug fixed, 1.0.10, 59391 lines.
|
||
* 2014-10-09, [Release v0.9.8](https://github.com/ossrs/srs/releases/tag/v0.9.8), all bug fixed, 1.0.0, 59316 lines.
|
||
* 2014-04-07, [Release v0.9.1](https://github.com/ossrs/srs/releases/tag/v0.9.1), live streaming. 30000 lines.
|
||
* 2013-10-23, [Release v0.1.0](https://github.com/ossrs/srs/releases/tag/v0.1.0), rtmp. 8287 lines.
|
||
* 2013-10-17, Created.
|
||
|
||
## Features
|
||
|
||
Please read [FEATURES](trunk/doc/Features.md#features).
|
||
|
||
<a name="history"></a>
|
||
<a name="change-logs"></a>
|
||
|
||
## Changelog
|
||
|
||
Please read [CHANGELOG](trunk/doc/CHANGELOG.md#changelog).
|
||
|
||
## Compare
|
||
|
||
Comparing with other media servers, SRS is much better and stronger, for details please
|
||
read Product([CN](https://github.com/ossrs/srs/wiki/v4_CN_Compare)/[EN](https://github.com/ossrs/srs/wiki/v4_EN_Compare)).
|
||
|
||
## Performance
|
||
|
||
Please read [PERFORMANCE](trunk/doc/PERFORMANCE.md#performance).
|
||
|
||
## Architecture
|
||
|
||
Please read [ARCHITECTURE](trunk/doc/Architecture.md#architecture).
|
||
|
||
## Ports
|
||
|
||
Please read [PORTS](trunk/doc/Resources.md#ports).
|
||
|
||
## APIs
|
||
|
||
Please read [APIS](trunk/doc/Resources.md#apis).
|
||
|
||
## Mirrors
|
||
|
||
Please read [MIRRORS](trunk/doc/Resources.md#mirrors).
|
||
|
||
Beijing, 2013.10<br/>
|
||
Winlin
|
||
|