情境
ApsaraVideo for Live是需要您在推流端,通過推流工具或者推流SDK將RTMP視頻流推向視頻中心(即ApsaraVideo for Live提供的推流地址video-center.alivecdn.com)。推流方法參考推流設定與操作,但是您可能遇到按照上述文檔操作無法成功推流的問題。本文檔中羅列了視頻推流過程中的常見問題,建議您按照下述的排查思路依次分析。
排查
用戶端推流方式錯誤
請檢查您的流設定中的URL和流名稱是否填寫錯誤。
說明此處以OBS工具的設定為例,現場以實際情況為準。
其中的URL是包括視頻中心以及AppName;而流名稱包括StreamName和QueryString參數(主要包括vhost參數,如果開啟鑒權則需要添加鑒權auth_key參數)。

請檢查用戶端推流工具的設定問題,常見的推流工具包括OBS、ffmpeg以及Adobe Flash Media Live Encoder軟體。建議您使用上述工具測試推流是否正常,如果正常請您查看原有推流方式的問題。
說明OBS的推流設定建議參見OBS推流工具。
如果其他推流工具正常,則說明是推流用戶端設定問題,請對比檢查不一致的設定項並嘗試調整。
音視頻編碼不合規
ApsaraVideo for Live要求H.264的視頻流和ACC的音頻流編碼格式,您需自行保證編碼格式滿足上述要求,否則會在直播過程中不同的播流協議可能產生問題。
您可以參考以下命令,通過ffmpeg工具查看流編碼格式。
ffmpeg -i rtmp://[$Your_Domain]/[$App_Name]/[$Stream_Name][$Your_Domain]:推流網域名稱。
[$App_Name]:推流地址中的AppName。
[$Stream_Name]:推流地址中的StreamName。
確認您的流編碼格式符合上述要求。

達到推流路數限制
ApsaraVideo for Live服務對每個使用者的直播網域名稱和單個網域名稱的並發推流路數均有限制。單個帳號限制建立20個直播網域名稱,直播中心為北京、上海、深圳時,預設每個直播加速網域名稱可並發推送300個原始(未轉碼)直播流。每個直播網域名稱限制300路並發推流。其他直播中心預設每個直播加速網域名稱可並發推送50個原始(未轉碼)直播流。如果您推流並發路數超過該限制,就會導致推流失敗。
另外,如果對應的AppName配置了即時轉碼的話,直播中心為北京、上海、深圳時,每個網域名稱下最多支援300路轉碼並發流,也就是一個網域名稱下最多同時輸出300路轉碼流。其他直播中心每個網域名稱下最多支援50路轉碼並發流。如果您推流並發路數超過該限制,就會導致推流失敗。
如果您需要查看當前並發的推流路數,請參見直播流管理。
說明具體推流路數限制以及釋放保留方式,可參考使用限制。
此直播流名被禁推
ApsaraVideo for Live提供了禁止推送某個AppName和StreamName對應直播流的功能。如果推流地址被加入黑名單,將導致無法推流成功。請檢查無法推流的推流地址是否在黑名單中。
您可以通過調用DescribeLiveStreamsBlockList介面,擷取指定網域名稱下被禁推的直播流資訊。
若要恢複直播流,您可以:
在控制台的流管理頁面,單擊對應直播流右側復原。
調用ResumeLiveStream介面,恢複直播流。
鑒權失敗
當您開啟鑒權功能後,該網域名稱的推流和播流都將需要加上鑒權auth_key參數。如果該鑒權參數到期或者簽名參數不正確將導致推流失敗,詳情請參見URL鑒權。
網路異常
推流端是需要將直播流通過RTMP協議推送到直播中心,因此如果該段網路出現問題是有可能出現推流異常,建議您先通過如下兩種方式自查:
在推流端
ping推流地址,測試是否有丟包。如果存在丟包,請聯絡網路電訊廠商進行排查。在推流端通過
telnet命令測試推流網域名稱的1935連接埠是否可以正常串連。如果無法串連,請嘗試使用不同網路環境測試,確認是否本網存在異常。
推流時間戳記使用了擴充欄位
用戶端推流對於視訊框架和音訊框架都會帶有兩個時間戳記,分別是pkt_pts和pkt_dts,分別表示幀顯示時間戳記和幀解碼時間戳記,您可以通過
ffprobe命令查看(具體命令ffprobe -show_frames rtmp://live.zhibotest.com/AppName/StreamName),部分結果如下圖。
其中的時間戳記是可以轉換為二進位,若時間戳記大於24位,讓推流用戶端確認下是否視訊框架大於max size,存在一幀包含多個chunk的情況。若是,修改推流用戶端,修改為將時間戳記加到每個chunk上,或者強制將pts值改小可解。
其他
如果上述方法均無法解決該問題,請您提交工單。關於如何提交工單,請參見聯絡我們。並提供下述資訊,以便對應的支援人員工程師協助解決問題:
推流地址與播流地址。
推流方式(使用什麼工具推流/如何推流)。
推流異常時,推流端出現怎樣的異常提示。
ping推流網域名稱的IP截圖。
telnet推流網域名稱1935連接埠的結果截圖。