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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...