一、背景
搭建流媒體服務的方式一般會採用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