Pornhub Web 開發者訪談

来源:https://www.cnblogs.com/madneal/archive/2019/10/13/11666529.html
-Advertisement-
Play Games

原文:Interview with a Pornhub Web Developer 譯者:neal1991 welcome to star my articles-translator, providing you advanced articles translation. Any suggest ...



原文:Interview with a Pornhub Web Developer

譯者:neal1991

welcome to star my articles-translator, providing you advanced articles translation. Any suggestion, please issue or contact me

LICENSE: MIT

無論你對色情內容採取何種立場,都無法否認成人網站行業對推動互聯網發展具有巨大影響。從將瀏覽器的視頻限制推送到通過WebSocket推送廣告,以便廣告攔截器無法檢測到它們,你必須足夠聰明才能在互聯網的前沿進行創新。

最近,我很有幸採訪互聯網最大的成人網站 Pornhub 的一名 Web 開發者。我想瞭解技術,Web API 如何改進以及在成人網站上工作的感受。請享用!

註意:成人產業競爭激烈,因此有一些他們無法回答的問題。我尊重他們保守商業機密的需要。

成人網站顯然會顯示許多圖形內容。在開發過程中,你是否使用了大量的占位符圖像和視頻?最終產品和開發時的內容和經驗有什麼區別?

實際上,我們在開髮網站時不使用占位符!其次,重要的是代碼和功能,介面是我們現在非常習慣的東西。一開始肯定會有一些學習曲線,但是我們大家很快就習慣了。

對於網路流和第三方廣告腳本,你如何在網站和功能開發過程中模擬這些重要的動態資源?

為了進行開發,播放器分為兩個部分。基本播放器實現核心功能並觸發事件。開發不會受其他因素干擾。為了在網站上進行集成,我們希望運行那些第三方腳本和廣告,以便我們儘早發現問題。在特殊情況下,我們將與廣告客戶合作,允許我們手動觸發通常可能是隨機的事件。

平均每個頁面可能至少包含一個視頻,GIF 廣告,一些 cam 表演者預覽以及其他視頻的縮略圖。你如何測量頁面性能以及如何使頁面保持最佳性能?有什麼你可以分享的技巧嗎?

我們使用一些測量系統。

  • 我們的播放器會向我們報告有關視頻播放性能和一般用法的指標

  • 用於一般站點性能的第三方 RUM 系統。

  • WebpageTest 私有實例,用於在可用的 AWS 數據中心中編寫測試腳本。我們主要將其用於查看給定時間可能發生的情況。它還使我們能夠查看來自不同位置和提供者的“瀑布”。

我必須假設前端最重要,最複雜的功能是視頻播放器。從在視頻之前加入廣告,標記視頻的精彩時刻,更改視頻速度和其他功能,你如何維護該資產的性能,功能和穩定性?

我們有一支專門致力於視頻播放器的團隊,他們的首要任務是持續監控性能和效率。我們為此幾乎使用了所有可用的東西;瀏覽器性能工具,網頁測試,指標等。我們進行的所有更新均通過可靠的質量檢查來確保穩定性和質量。

專門的視頻團隊有多少人?團隊中有多少前端開發人員?

我要說的是,團隊規模傾向於基於產品規模的平均水平。

在成人網站上工作期間,你如何看待前端未來的變化?哪些新的 Web API 使你的生活更輕鬆?

我肯定在前端世界的每個方面都看到了很多改進;

  • 從純 CSS 到最終使用 LESS 和 Mixins,再到使用具有媒體查詢和圖片標簽的靈活 Grid 系統,以適應不同的解析度和屏幕尺寸

  • jQuery 和 jQueryUI 慢慢地被淘汰,因此我們將回到 vanilla JS 中更高效的面向對象編程。在某些情況下,框架也非常有趣

  • 我們喜歡新的 IntersectionObserver API,對於以更有效的方式載入圖像非常有用

  • 我們也開始使用畫中畫 API,以便在我們的某些頁面上播放該浮動視頻,主要是為了獲得用戶對該想法的反饋。

展望未來,有沒有你想要更改,改進甚至創建的 Web API?

其中有一些是我們希望改變或改進的;Beacon,WebRTC, Service Workers 以及 Fetch:

  • Beacon:在 IOS 上存在 pageHide 事件無正常工作的問題

  • Fetch:沒有下載進度,也沒有提供攔截請求的方法

  • WebRTC:如果解析度不夠大,則即使進行屏幕共用,Simulcast 層也會受到限制

  • Service Workers:調用 navigator.serviceWorker.register 不會被任何 Service Workers 的 Fetch 事件處理程式攔截

WebVR 在過去幾年中一直在進步--WebVR 在當前狀態下作用有多大,成人網站為支持 VR 內容付出了多少努力?觸覺在你們網站上的 WebVR 中有起到作用嗎?

我們正在研究 webXR 以及如何最好地適應新興的空間計算用例,作為最大的發佈平臺,我們需要支持創作者和用戶,無論他們想體驗我們的內容如何。但是,我們仍在探索這些新媒體應具有什麼樣的內容和平臺。

我們是第一個支持 VR,電腦視覺和虛擬表演者的主要平臺,並將繼續推動新技術和開放互聯網的發展。

每個頁面上的媒體和內容種類繁多,那麼桌面設備與移動設備之間最大的考慮是什麼?

功能主要受操作系統和瀏覽器類型的限制。當涉及一組套完全不同的訪問和功能時,iOS 對比 Android 是一個完美的例子。

例如,某些 iOS 移動設備不允許我們在全屏模式下使用自定義視頻播放器,而是強制使用本機 QuickTime 播放器。我們提出新想法時必須考慮這一點。另一方面,Android 為我們提供了完全的控制權,我們可以將功能在全屏模式實現。

HLS 中的自適應流式傳輸也是另一個示例,當涉及到 HLS 流式傳輸質量時,IE 和 Edge 需要有所顧慮,因為我們需要防止某些更高質量的內容,否則視頻將不斷卡頓並出現偽像。

當前針對你工作的成人網站的最低瀏覽器版本支持是什麼?是否已經淘汰 IE 瀏覽器?

我們對 IE 的支持時間很長,但是最近放棄了對 IE11 之前的任何版本的支持。有了它,我們也停止了為視頻播放器使用 Flash。我們主要關註 Chrome,Firefox 和 Safari。

更廣泛地說,你能否分享一些有關典型成人網站技術棧的信息?伺服器和/或前端?你正在使用哪些庫?

我們的大多數網站都以以下內容為基礎:

  • Nginx

  • PHP

  • MySQL

  • Memcached 和/或 Redis

在適當的地方使用其他技術,例如 Varnish,ElasticSearch,NodeJS,Go,Vertica。

對於前端,我們主要運行原生 Javascript,我們逐漸擺脫了 jQuery,我們才剛剛開始使用框架,主要是Vue.js

從局外人的角度來看,成人網站通常看起來很相似:很多視頻縮略圖,聚合的視頻內容,攝像頭表演,廣告。作為從事這些工作的人,使成人網站與眾不同的特征是什麼?

我們非常努力地為每個品牌賦予不同層次的獨特性;內容庫,UX 和功能集,以及許多不同的演算法。

在你申請這份工作和麵試之前,你對在成人場所工作的想法是什麼?你有猶豫嗎?如果是這樣,你如何釋懷的?

這真的從來沒有困擾過我,最終挑戰是如此吸引人。數以百萬計的人會使用我正在開發的功能確實令人鼓舞。事實證明,這很快就成立了,我第一次的工作成果上線了,我感到非常自豪,我的確告訴所有朋友去看看!色情片永遠不會消失的事實也使工作穩定得到了保證!

就最終產品而言,分享下你在成人網站上工作可能與在本地互聯網公司上工作不同。你會羞於告訴朋友,家人和熟人在成人網站工作嗎?你是否會猶豫告訴別人你在成人網站工作?

我為能夠為這些產品工作而感到自豪,與我親近的人都知道並著迷於這些產品。它始終是交談,笑話的絕佳來源,而且非常有趣。

曾在成人產業以外的機構工作過,和在成人網站工作時氣氛有差異嗎?

這裡的氣氛非常輕鬆友好。除了在這裡比我以前工作過的任何地方都大得多的事實外,我沒有註意到和其他機構在工作文化方面的任何重大差異。

作為前端開發人員,你與哪些團隊合作最緊密?最常見的日常交流方式是什麼?

我們與後端開發人員,QA 測試人員和產品經理平等地合作--大多數時候,我們只是在彼此的辦公桌旁交談。另外使用 cat(MS Teams)非常普遍。然後就是電子郵件。

最後,作為在成人網站上工作的前端開發人員,你有什麼想分享的嗎?

作為創造用戶如何體驗如此廣泛使用的產品的一部分,確實令人興奮。隨著技術的不斷發展,我們通常處於趨勢和技術重大變革的最前沿,這使它保持樂趣和挑戰性。

訪談結束

我發現我們的採訪確實很有啟發性。我很驚訝他們在開發功能和設計時沒有使用圖像。很高興看到 Pornhub 繼續使用 WebXR,WebRTC 和 Intersection Observer 推動互聯網的前沿發展。我也很高興看到他們認為當前的 Web API足夠了從而開始移除 jQuery。

我真的希望我能夠從中獲得更多具體的技術提示;性能和巧妙的技巧。我敢肯定,他們的源代碼背後有很多知識要學習!你會問什麼問題?

可以掃描二維碼或者搜索 mad_coder 關註微信公眾號,點擊閱讀原文可以獲取鏈接版原文。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 筆者最近在學習Element UI,覺得它提供的日期選擇器既簡單又美觀,於是仿照著寫了一個日期插件。筆者使用到的技術有ES5、CSS和HTML,控制項相容IE10+和谷歌瀏覽器。有一點需要註意,筆者使用到iframe包裹彈出層,由於瀏覽器的同源安全策略,代碼必須得放到tomcat的webapps文件夾 ...
  • 響應式開發 (就是利用媒體查詢針對不同寬度的設備進行佈局和樣式的設置,從而設配不同設備的目的) 響應式佈局容器響應式需要一個父級作為佈局容器,來配合子級元素來實現變化效果 原理:不同屏幕下,通過媒體查詢來改變這個佈局容器的大小,再改變裡面子元素的排列方式和大小,從而實現不同屏幕下,看到不同的頁面佈局 ...
  • rem即是以html文件中font-size的大小的倍數rem佈局的原理:通過媒體查詢設置不同屏幕寬度下的html的font-size大小,然後在css佈局時用rem單位取代px,從而實現頁面元素大小的動態適配,做出更漂亮整潔的頁面rem佈局的好處:1.頁面整潔2.動態適配缺點:1.需要計算rem, ...
  • element.offsetLeft/Top 獲取元素相對於最近的有定位的父元素的坐標,如果沒有有定位的父元素,則是文檔坐標 element.scrollTop/Left 獲取元素滾動捲去的距離 element.offsetWidth/Height 獲取元素的寬度高度(包含邊框) element.c ...
  • 後臺開發人員不擅長前端UI界面,而小型軟體公司沒有專職美工崗位,開發人員只能藉助開源UI框架,復用已有組件,完成用戶操作界面。EasyUI是基於jQuery的UI插件集合體,可幫助開發者輕鬆構建網頁。 官方地址:http://www.jeasyui.com/ 一、引用EasyUI 官網下載EasyU ...
  • 前言 vue.js是一套構建用戶界面的漸進式框架,vue.js的目標是通過儘可能簡單的API實現響應的數據綁定和組合的視圖組件。 vue通過DOM事件操作和指令來進行視圖層和模型層的相互通訊,會為每一處需要動態更新的DOM節點創建一個指令對象。每當一個指令對象觀測的數據變化時,它便會對所綁定的目標節 ...
  • 正值前端組件化開發時代,那麼必然離不開目前最火的構建工具——webpack(grunt,gulp等暫且不談)。說到這裡,剛好有幾個問題: 為什麼運行打包命令之後, 文件可以轉成 文件 為什麼運行打包命令之後, 文件可以轉成 文件 為什麼運行打包命令之後, 語法可以轉成 語法 "[外鏈圖片轉存失敗,源 ...
  • 幹了這麼多年的前端,之前面試的時候經常會遇到面試官提問:你是如何理解HTML的語義化的? 說實話,之前遇到這個問題的時候,都是從網上找參考答案,然後記下來,用自己的語言重新組織一下,就變成自己的理解了。 為什麼說要重學HTML5的語義化,是因為今年以來,公司安排了一項任務給我,讓我做一個自項目的官網 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...