一、背景
搭建流媒體服務的方式一般會采用nginx+rtmp和srs服務兩種,前者是nginx加上插件所用,而后者是專門為了為了流媒體而生,在這一節中我們將從頭搭建srs流媒體服務
二. 運行環境
為了此服務后期部署到生產環境中,筆者采用docker方式來搭建此服務,docker目前屬於基礎性軟件了,在本文中就不再細述如何安裝,大家可以去www.docker.com
下載安裝包安裝即可;一般正式的生產環境中我們通常使用Linux系統作為服務器,所以我本文中同樣使用了Linux系統,不過我選擇了我比較喜歡的Ubuntu系統來搭建,其他Linux系統搭建流程基本一致。
2.1 docker容器
我們首先需要運行一個Ubuntu的容器,在運行容器之前,我們需要想好運行容器的一些參數,比如說我們需要搭建rtmp服務,rtmp默認端口是1935,這個時候我們就需要將此端口映射出去;再比如說安裝nginx后需要進行驗證Nginx是否安裝完成,需要開放一個http端口,那么同樣需要映射出去,但為了防止和宿主機的80端口產生沖突,這里我們使用8081端口替代80端口;最后服務搭建完成了,還需要播放視頻,因此需要將視頻文件拷貝到容器中,這時候需要掛載一個目錄將視頻文件放到容器中去,因此docker容器運行命令如下所示
docker run --name srs -v /Users/song/files:/root/files -d -i -p 1935:1935 ubuntu:18.04 && docker ps
命令很執行完成之后,docker返回結果如下圖所示
在上圖中中可以看到已經有一個容器運行了,接着我們需要進入容器安裝nginx和rtmp模塊,進入容器命令如下所示
docker exec -it srs bash
命令執行完成之后,返回信息如下圖所示
在上圖中從光標位置的左側可以看到已經顯示了root賬戶名稱,說明已經進入容器成功;
2.2 國內加速源
docker的Ubuntu鏡像apt軟件源默認使用官方域名,這個域名在國內訪問非常慢,為了后續安裝速度能夠更快,我們將apt的軟件源更換成阿里雲源的地址,執行命令如下所示
echo 'deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
' > /etc/apt/sources.list && cat /etc/apt/sources.list
命令執行之后,返回的信息如下圖所示
從上圖中可以看到已經執行成功,已經使用阿里雲的軟件源替代了默認的軟件源;
2.3 更新軟件源列表
接下來我們更新一下本地的軟件源信息,執行命令如下所示
apt update
命令執行之后,返回的信息如下圖所示
從上圖中可以看到已經從阿里雲中更新了軟件源信息,更新速度也非常快,到此我們已經完成運行環境的基礎准備。
三、服務搭建
在搭建SRS服務過程中,需要先解決依賴,然后安裝SRS服務,安裝完成之后需要配置服務
3.1 安裝依賴
因為我們采用源碼編譯,在編譯過程中會依賴一些其他軟件,所以我們需要提前將這些軟件編譯好,安裝依賴我們直接采用apt安裝,如下命令所示
apt install -y git gcc g++ unzip make python
命令執行后,返回的信息如下圖所示
在上圖中我們可以看到上面的依賴已經安裝完成,接着我們通過Git下載最新的srs源碼
3.2 安裝SRS
srs官方把源碼托管在GitHub中,國內訪問GitHub相對較慢,這里我通過碼雲復制了一個出來,下載srs執行命令如下所示
git clone https://gitee.com/songboy/srs.git && ls srs
命令執行后,返回的信息如下圖所示
在上圖中我們可以看到源碼已經克隆完成,並展示了srs項目的目錄結構,在項目中有一個trunk
的文件夾,源代碼都在這個里面,我們通過cd命令進去並查看目錄,執行命令如下所示
cd srs/trunk/ && ls
命令執行后,返回的信息如下圖所示
在上圖中我們可以看到configure
文件,這個文件是為了讓一個程序能夠在各種不同類型的機器上運行而設計的,在使用make編譯源代碼之前,configure會根據自己所依賴的庫而在目標機器上進行匹配,我們執行如下命令便可以編譯
./configure && make
命令執行完成后,返回的信息如下圖所示
在上圖中我們可以看到提示編譯已經完成,並給出了一個啟動命令的提示
3.3 啟動服務
在啟動命令中有一個配置文件,我們可以通過cat命令查看一下配置文件里面的具體內容,執行命令如下所示
cat conf/srs.conf
命令執行后,返回的信息如下圖所示
在上圖中我們可以看到監聽的端口,以及日志文件存放位置等信息,這里我們就是要默認值即可,執行啟動命令如下所示
./objs/srs -c conf/srs.conf
命令執行后,返回的信息如下圖所示
在上圖中我們可以看到日志文件的輸出信息,此時程序以及在后台啟動了。
四、服務驗證
我們可以使用OBS進行一個推流測試;docker運行的容器就在我本地,因此這里我使用的推流地址如下
rtmp://127.0.0.1/live/tangqingsong
4.1 推流測試
啟動OBS,然后打開設置,找到推流項;服務選擇自定義,然后將上面的地址填寫進去,如下圖所示
填寫完推流地址之后,我們點擊確定按鈕,然后回到OBS的主界面,點擊開始推流按鈕,就會開始向SRS推流,如下圖所示
在上圖中我們可以看到已經在推流當中了,下方顯示占用CPU資源很高
4.2 拉流測試
接着我們再使用VLC播放器進行拉流測試,拉流地址和推流地址是一樣的,拉流效果如下所示
在上圖中我們可以看到VLC已經播放成功
作者:湯青松
日期:2019-12-13