跳到主要內容

17 Media 直播技術大解密

亞洲即時互動媒體龍頭 17 Media 歡慶成立四周年,透過深厚的即時互動工程技術底蘊、絕佳使用者體驗、流暢不中斷的優質直播內容在全球交出漂亮的成績單。17 Media 定期舉辦直播技術分享會 17 Tech Night( 17 科技之夜),邀請工程技術團隊現身分享 17 直播的開發旅程。

後端工程團隊合作無間,打造無時差的順暢直播體驗

17 Media 全球註冊用戶數達4,200萬、簽約的內容創作者近20,000人,近期更將內容生產、直播娛樂的版圖拓展至香港、日本、美國及馬來西亞等地。而為加強即時互動性、讓尖峰時段的直播流量不中斷,作為 17 Media 穩定運作的強力後盾,工程技術團隊結合了多種先進的軟體開發流程,不斷地優化和改良後台系統與產品設計,才能讓 17 Media 的優質內容流暢不間斷。

17 Media 後端工程部總監陳義雄表示,直播平台的順暢度是 17 Media 的首要目標,無論在不同時區的尖峰時刻,都需在開啟直播間之後的 0.3 秒內進入直播畫面;或是當有數百名直播主一起開播的線下活動、與電視台合作的直播益智互動節目進行時,都會為平台帶來瞬間流量以及可能的畫面延遲問題。陳義雄也分享,「技術團隊在克服所有裝置的畫面延遲上,有許多維運細節,即使只有1%的用戶服務出問題,17 Media 的工程技術團隊也能早一步預警並快速協助各供應商調整並維護。這些細節都是經過我們工程技術團隊在系統背後的無數次打磨,才能無時差的將優質的直播畫面提供給用戶、讓直播主與用戶順利互動。」

SRE 團隊作為產品幕後推手,自動化追蹤系統運作,維持 17 Media 競爭力

為因應 17 Media 的跨國直播服務,直播流量尖峰已不僅限於特定時段,17 Media 工程技術團隊首重靈活調整,以應付各種負載需求。17 Media 的工程團隊分工中,除了有後端工程師團隊負責開發、測試新功能外,17 Media 亦設有 SRE(Site Reliability Engineering,網站可靠性工程)團隊,管理 17 Media 複雜的基礎架構、資料庫、建置開發環境等,共同提供安全、可靠、具擴充性(Scalable)的解決方案,用快和穩定來維持競爭力。

17 Media 資深 SRE 工程部經理林毅民也分享:「17 Media SRE 團隊建立了24小時的 On-Call 制度,負責非常細緻的系統運作監控,追蹤數百項系統數據、制定量化的指標,做為系統發布警報的標準並每日發布,讓團隊能快速了解當前基礎架構的運作狀況,讓系統運行穩定並且提供開發人員能極大化產出速度的開發環境。」

iOS 團隊建立一套自動化整合及部署流程,降低直播 App 送審時被拒的風險

17 直播 App 做為公司產品本身,iOS 團隊深負重任,在後端穩定平台營運時,持續提供最新的功能給用戶,並提升 App 穩定性與優化使用者體驗,用深厚的開發經驗降低產品送審時被拒的風險、讓優質內容和創作者能持續被看見。

17 Media 資深 iOS 系統總監王瑞璽分享,「17 直播 App iOS 端用戶眾多,也意味著是一項艱難的挑戰。」17 直播在 AppStore 嚴謹的審查條款下曾在初期遭下架,近期更因拓展的國家、語系不斷增加,讓 17 直播 App 在全球持續「符合審查規範」並維持「每週一次更新」的任務更顯艱鉅。

17 Media iOS 工程技術團隊分享,人為疏忽如部署錯誤版本、使用不合規的關鍵字、圖片或描述等,都可能造成送審被拒、App被下架,造成營運上的混亂和用戶的困擾。王瑞璽表示,「為解決這個問題,17 Media iOS 團隊發展出一套自動化流程,整合 17 Media 自己的開發流程、團隊溝通平台 Slack 與第三方系統,讓系統能自行針對 AppStore 的送審流程進行自動化驗證和嘗試,自動化翻譯、整合素材、最後一鍵打包並送審,讓原本繁瑣的手動操作簡化成一條簡單的指令,增加團隊效率同時有效降低17 直播 App 送審時被拒絕或下架的風險。」

17 Media iOS 團隊導入 Apple 新技術,創作者一秒變虛擬主播!

虛擬主播(V-Liver)風潮從日本吹進台灣,17 Media 自去年起加入近百位虛擬主播,成台灣第一個可透過直播和虛擬主播互動的原生平台。虛擬主播廣受粉絲歡迎,也吸引許多創作者想要加入虛擬主播的行列,迎上二次元的 V-Live 風潮。

Apple 在全球開發者大會 WWDC 15 上公布了 ReplayKit,是一個讓直播主及創作者們可以串流手機螢幕畫面、即時分享到不同平台的框架,17 Media iOS 團隊看到後立即著手研究和導入。王瑞璽指出,「在過去,創作者要打造虛擬主播,只能透過電腦上的 OBS 影音串流直播工具來進行,隨著日漸增加的手機直播需求,我們也希望能讓虛擬主播有更便利的開播方式,因此 17 Media iOS 團隊即投入研究並導入 Apple 的此項新技術,現在創作者只要用一支手機就可以化身虛擬主播、一鍵開播!」

在同一支手機上,只要透過一個第三方 App 來製作虛擬化人像、變身後的影像可以直接在 17 直播 App 上開播,過程簡單快速,讓虛擬主播上手更容易、也讓用戶能有更多虛擬與現實融合的娛樂新體驗。

17 Media 團隊擁抱創新,開發開源軟體,號召技術人才一起打造優質直播環境

首屆 17 Tech Night 邀請 17 Media 工程技術團隊與業界分享後端技術,深獲聽眾好評。第二屆 17 Tech Night 則邀請與使用者第一線接觸的 iOS 工程團隊,分享團隊使用的各項技術以打造使用者最佳的即時互動體驗,進而完美呈現用戶眼前的 17 直播 App。

17 Tech Night 已成為每季舉辦的盛會,並期待有更多新世代技術人才加入 17 Media,一起打造更好的使用者體驗、可信賴的直播環境,帶給用戶更多價值、協助更多人透過直播完成夢想。

17 Media 人才招募訊息:https://www.jobs.17.media/?lang=zh

留言

這個網誌中的熱門文章

COC 通報處理說明公告 - 20240811 通報事件

各位好, COSCUP COC 服務小組於 2024 年 8 月 11 日接獲一件通報,內容涉及在會期干擾議程進行;並於會後持續發送私訊予會中結識的講者;同時,該行為人亦被紀錄於活動當日干擾志工執行勤務。 有關此事件的處理過程,詳如下述: COC 服務小組接到通報後,於 8 月 15 日正式成立專案小組進行討論與檢視相關資料。經查,通報內容與 COC 條款「持續干擾議程或活動的正常進行,無視工作人員或與會者的制止」相符。同一行為人於大會期間,另有兩位會眾通報類似事件,COC 服務小組皆已明確指正其行為並重申 COC 規範和界線。綜合此次會後通報,行為人經提醒仍多次抵觸 COC 條例。 有鑒於上述行徑已明確影響 COSCUP 其他會眾之權益,COC 服務小組將依照 COSCUP COC 之辦法記錄事件處理過程及結果、行為人資料等,於籌備團隊組長群資料夾建立文件,以俾後續籌備團隊審慎思量該名行為人未來的參與形式與程度。 在此,感謝會眾願意信任 COC 和 COSCUP 團隊並且將其所遇到的事件於會後彙整提供予我們。另本次通報中,通報人所提及之部分事項,因非屬 COSCUP 大會參與期間和相關行為,已建議通報人另行循其他正規途徑處理。在此聲明, COSCUP 的 COC 落實並非要拒任何人於門外,而是希冀透過針對行為本身的評估,為無論志工、社群協調人、講者、廠商與所有會眾營造舒適與安全的交流環境。 我們在乎所有人於 COSCUP 大會的各種參與體驗與感受,如果您在大會和籌組期間有相關困擾,籌備團隊志工將會竭力協助釐清,希望一同打造友善的 COSCUP 與會環境。 COSCUP 2024 COC 服務小組

【攤位大地遊戲(開源巔峰挑戰賽)】Booth Reward Activity! 2024

/English Below/ 來啊,造訪攤位掃 QRCode,集點數換 2024 年限定贈品啊! 一年只有這一檔,錯過要再等一年! 在找工作嗎?想認識不同的社群嗎?想獲得 COSCUP 2024 專屬的限量贈品嗎? 利用空餘時間去各個攤位聊聊天、看一看,就可以參與大地遊戲拿獎品喲! 大地遊戲怎麼玩:​​ (歡迎順路參與 參與者大調查),填寫表單取得 OPass 票券,並下載與登入 OPass App: 取得 OPass 票券 。 前往 TR 309、312、409-1、515、516 逛各攤位。 在攤位前打開 OPass 的「我的票卷」,秀出 Opass QRcode 讓攤位人員掃描取得點數。 到 TR309 的「大會攤位」兌換贈品,數量有限! 造訪每個攤位掃描後,可獲得 5 點,今年有 28 攤 完成一日志工任務後,可獲得 50 點,至多可解 4 次 擔任講者,可享福利 400 點(請以收到的登入連結進入,每名講者限領取乙次) 今年的紀念品除了可以現金購買,也可以用點數兌換呦! ≡≡≡≡ 集點方法 ≡≡≡≡ 上方每ㄧ個方框,都是ㄧ個攤位或者ㄧ個小任務,每當你造訪完成任務後,即可打開「我的票券」中顯示你的 QRcode 給關主獲取點數,您可以在上方看到您的戰果點數。當您心滿意足準備離開大惠會場前,記得到下述地方將您的點數兌換成滿滿的回憶! ≡≡≡ 點數兌換處 ≡≡≡ 【TR309 外:大會攤位】 1 點即是 1 元,您可以在大會攤位上購置各種精美紀念品,包含滑鼠墊、鍵帽、透卡與紀念 T 恤!。 ≡≡≡ 點數兌換規則 ≡≡≡ 您可以於【紀念品攤位】旁的點數兌換區把點數兌換

利用 Jitsi 建立個人化的視訊會議平台

  近期因為疫情的關係,越來越多企業開始實施分流或在家工作,視訊會議的需求也日益增加。 在商用解決方案選擇上,有不少企業會選擇知名品牌的產品,例如  Cisco Webex 、 Google Meet 、 Microsoft Teams 、 Zoom  都是很不錯的方案。 KKBOX 集團在去年便試行及做好充分 work from home 的準備,今年五月也因應疫情升溫,全員 work from home 至今兩個月有餘。 當然,取之 Open Source,也要對社群有些貢獻。在這一屆 COSCUP,我們要來介紹 Open Source 圈中也很知名,效果也很不錯的一套視訊會議平台: Jitsi 。 除了基本的視訊會議功能外,在最後我們也會示範如何透過 Jitsi 畫面輸出到 YouTube/Twitch 或其他支援 RTMP 的平台進行直播。 由於篇幅有限,且 Jitsi 可以調整的細節非常多。今天我們純粹很快速的示範,如何簡單的建置出一個 Jitsi 環境,並提供單場會議內容錄影或直播。 Jitsi 的文件可以在 這裡 找到。 今天透過 AWS Lightsail 的 $10/month instance(1 core CPU + 2GB RAM + 60GB SSD),作業系統則是 Ubuntu 20.04 來示範。當然,使用其他 VPS 亦可,大同小異,這邊直接跳過 VPS 相關的建置過程。 *firewall 相關資料參考 這裡 及 這裡 。 針對系統做必要的更新 基本的 apt repository 更新: $ sudo apt update 因為後面要示範的會議錄影及直播需要使用 ALSA loopback device,如果是 EC2 or Lightsail 則需要額外安裝 generic kernel( 註 ): $ sudo apt install linux-image-generic linux-headers-generic linux-image-extra- virtual 接著做系統套件們的更新: $ sudo apt dist-upgrade $ sudo apt autoremove 如果是 AWS EC2 or Lightsail 則需要另外再將預設的 AWS optimized kernel 移除( 註 ): $ su