Shopify如何在瀏覽器之外使用WebAssemblyShopify如何在瀏覽器外使用WebAssemblyShopify致力于讓大多數商家需要的功能變得簡單易用,通過接口在Shopify平臺上進行查詢、擴展和更改,從而為商家提供更多的可能性。有了這些接口,我們豐富的合作伙伴生態系統可以解決許多問題。這個生態系統主要......
Shopify致力于讓大多數商家需要的功能變得簡單易用,通過接口在Shopify平臺上進行查詢、擴展和更改,從而為商家提供更多的可能性。有了這些接口,我們豐富的合作伙伴生態系統可以解決許多問題。這個生態系統主要由“App”(獨立托管的Web服務)來運營。該應用程序通過網絡與Shopify進行通信。這種模式雖然功能強大,但是會帶來一系列的技術問題。我們的合作伙伴需要建立可以隨著Shopify的規模而擴展的Web服務,這使得一些資源有限的合作伙伴更加捉襟見肘。即使合作伙伴擁有無限的資源,但與Shopify的通信所帶來的網絡延遲,也足以讓我們的App在要求高時效性的用例中失敗。
我們希望我們的合作伙伴可以專注于使用他們的專業知識來解決問題,而不是花費時間來管理可伸縮的Web服務。為了實現這個目標,我們保持了不受信任的伙伴代碼的靈活性,并在我們的基礎設施上運行它。為了保證這些代碼的性能、安全性和靈活性,我們選擇了WebAssembly作為通用格式。
web程序集
什么是WebAssemblyWebAssembly.org給出了如下定義:
WebAssembly (Wasm)是一種基于棧虛擬機的二進制指令格式。Wasm是一個為編程語言設計的可移植編譯目標,它使客戶機和服務器應用程序能夠部署在Web上。"
要了解更多關于WebAssembly及其歷史的信息,您可以瀏覽這篇由Mozilla的Lin Clark撰寫的圖文并茂的文章。本文在此不再贅述。
Wasm通常與JavaScript一起運行在瀏覽器中,但Shopify采取了不同的方式,在瀏覽器外運行Wasm,不使用JavaScript。作為一種高性能語言,Wasm絕不是JavaScript的簡單替代品:它是為Web和非Web嵌入而設計的,解決了瀏覽器和代碼執行引擎中廣泛存在的一個難題,即如何在不可信環境中高效執行程序。Wasm滿足我們的三個主要技術要求:安全性、性能和靈活性。
安全
運行不受信任的代碼非常危險。本質上,這些代碼不僅難以預測,而且很可能對整個Shopify平臺造成損害。雖然市面上沒有100%安全可靠的應用程序,但我們仍然要防范安全漏洞,并在問題發生后采取措施減輕其影響。
Wasm將代碼執行放在基于堆棧的沙盒環境中,依靠顯式導入與主機通信。因此,我們不能在Wasm中編寫任何惡意代碼。我們只能使用提供的輸入端口來操作虛擬環境。Wasm在這方面不同于字節碼,因為字節碼直接引用它們想要運行的計算機或操作系統。
Wasm還有許多不同的功能來保護用戶免受錯誤代碼的影響,包括受保護的調用堆棧和運行時類型檢查。關于Wasm安全模型的更多細節在WebAssembly.org上提供。
表演
在電子商務領域,更快的運行速度是商家推動業績增長的必要武器。如果Shopify提供的功能不能平衡加載時間和定制價值,那么這個功能就根本沒有價值。
Wasm自己的設計充分利用了常見的硬件功能,在各種平臺上發揮最接近的原生性能。面向追求最高性能,優化瀏覽器執行的開發者群體。因此,無論是現在還是未來,Wasm及其外圍工具在設計上都將側重于性能優化。
靈活性
能夠幫助開發者提高開發效率的代碼執行服務才是真正有用的服務。Wasm作為一種字節碼格式,兼容各種編譯器,為代碼開發者提供支持多種編程語言的一流開發體驗。這也使我們能夠在不改變底層執行模型的情況下提供多語言支持。
基于社區
Shopyify基本保持了相同的開發目標和設計,這為我們選擇Wasm提供了一個技術上的理由,但事實并不僅限于此:我們選擇Wasm不僅關乎技術,更關乎人。如果Wasm生態系統被忽視了,或者只是奄奄一息,那么我們不會選擇它。集結號社區充滿活力和創新,潛力無窮。自從加入這個熱情的社區后,Shopify受益匪淺。
同樣,我們也在為社區貢獻自己的力量。通過收集用戶反饋,探索功能缺陷,并為我們使用的開源工具提交代碼貢獻。我們相信這為與WebAssembly社區建立良好的互利合作關系奠定了堅實的基礎基礎,我們也期待在未來繼續為這個充滿活力的社區貢獻我們的力量。
代碼執行服務的架構
在簡單介紹了WebAssembly以及我們選擇它的原因之后,接下來就是深入探討我們的運行方案了。
我們使用Lucet,一個最初由Fastly開發的開源工具。Fastly,一家公司,為大量短命的、不可信的模塊提供了可編程的邊緣云平臺,使得它們可以在盡可能接近其發起地的地方執行請求。這和我們的合作伙伴提供的代碼是一個問題,所以我們很自然的選擇了Lucet。
朗訊
Lucet是Wasm的運行時和編譯器。Wasm中的模塊保證了系統的安全性。因為我們不能在Wasm中編寫惡意代碼,所以Lucet利用Wasm模塊的驗證來檢查安全性。驗證后,模塊會被編譯成可執行文件,性能可以達到原生狀態。此外,Wasm還支持預編譯,可以避免運行時編譯帶來的延遲。Lucet container在啟動時不需要做任何事情,這使得它的啟動時間達到了驚人的35μs。如果你對Lucet及其工作原理感興趣,可以查看Fastly的CTO泰勒·麥克馬倫的視頻。
Shopify Wasm發動機工作原理流程圖
我們將Lucet包裝在一個管理I/O和模塊存儲的Rust Web服務中,并稱之為Wasm engine。運行時,Shopify通過Web請求調用Wasm引擎來處理一些功能。之后,引擎在站點的上下文中調用應用程序輸出,其中上下文可能涉及創建折扣、執行約束或同步任何商家希望在平臺中進行個性化定制的服務。
行駛性能
下圖顯示了從我們最新的性能測試中提取的一些指標。我們選擇了一個小函數和逆行測試:讓模塊限制添加到購物車的商品數量。測試過程中,每分鐘執行10萬個模塊,時長約5分鐘。
模塊執行所需的時間
此圖表顯示了執行模塊所需時間的詳細信息,包括容器的I/O和模塊的執行。y軸代表時間(單位:ms),x軸代表測試運行的具體時間。
圖中淺紫色的圖例表示在Lucet中執行模塊所需的時間,其寬度徘徊在100μs左右,其余圖標是I/O處理和引擎的細節。可以看出,總執行時間約為4 ms。所有時間顯示都是第99個百分比(99p)。為了更好的理解圖中時間的含義,我們來對比一下Shopify中優秀的在線商店渲染服務Storefront Renderer的測試請求時間。
店面渲染器響應時間
此圖表顯示了一段時間內店面呈現器的請求時間。y軸表示請求時間(單位:秒),x軸表示返回值的具體時間。淺藍色線代表大約700毫秒的第99個百分比。
如果粗略估計模塊處理時間在5毫秒以內,可以說Lucet執行時間的性能影響幾乎可以忽略不計。
生成WebAssembly
為了讓我們優秀的執行引擎發揮作用,我們還需要授權開發者創建兼容的Wasm模塊。Wasm的作用不是讓用戶自己寫代碼(如果他們愿意,當然可以寫),而是作為編譯目標存在。這讓我們思考以下問題:我們支持哪些編程語言,支持到什么程度。
理論上,Wasm支持的任何開發語言都是可能的。然而,我們更希望開發者能夠專注于為企業解決問題,而不是研究如何符合我們的API。這就是為什么我們選擇單一語言Ruby支持,并為開發人員提供快速入門工具。但是,由于Ruby動態語言的特性,我們不能直接將其編譯成Wasm,涉及編譯解釋器的解決方案會有嚴重的性能損失。正因為如此,我們最終決定采用靜態編譯的語言,并把動態語言編譯的可能性留給了未來。
通過我們的研究發現,Shopify生態系統中的大多數開發者都能熟練應用JavaScript。不幸的是,JavaScript和Ruby一樣,是一種動態語言,所以不得不排除。最后,我們選擇了一種語法類似于TypeScript的開發語言:AssemblyScript。
使用匯編腳本
盡管WebAssembly支持大量的開發語言,但有兩種主要類型的編譯器我們不能使用:
生成環境或開發語言的特定產品的編譯器,即節點或瀏覽器。(例如Asterius、Blazor)
僅適用于特定運行時的編譯器。這些編譯器生成的模塊依賴于特定語言的特定導入,通常是為了支持某些特定語言的標準庫而存在的,這樣它們就可以在系統調用或運行時擁有可用的函數。因為我們不想被鎖定在某個特定的語言中,所以這種編譯器不在我們的考慮范圍之內。(例如流明)
這些強大的編譯器在其他情況下可能會創造奇跡,但不幸的是它們不能被我們使用。我們需要可以生成WebAssembly的工具,而不是WebAssembly支持的工具。腳本是我們選擇的工具。
與WebAssembly中的其他工具一樣,AssemblyScript仍在開發中。它缺少一些關鍵功能,比如閉包支持,在邊緣情況下仍然會報告錯誤。這時,社區的重要性就顯現出來了。
開發語言AssemblyScript及其外圍工具擁有活躍用戶的愛好者和維護者社區,他們自2019年Shopify首次使用AssemblyScript以來一直支持我們。而且我們還通過OpenCollective長期貢獻代碼支持社區。我們已經編寫了一個語言服務器,在實現閉包方面取得了一些進展,并為編譯器和外圍工具提供了錯誤修復。
我們還將AssemblyScript整合到我們的早期工具中。在Shopify CLI中,我們允許開發人員通過命令行集成AssemblyScript來創建、測試和部署模塊。為了提高開發效率,我們提供了一個SDK,可以處理Shopify定義對象(比如“錢”)的底層實現。除了這些工具之外,我們還建立了一個允許合作伙伴監控模塊的系統,以便他們可以在模塊出現故障時收到警報。我們的最終目標是讓合作伙伴能夠將他們的代碼遷移到我們的平臺上,而不會失去代碼在原始平臺上的靈活性和可觀察性。
特別聲明:以上文章內容僅代表作者本人觀點,不代表ESG跨境電商觀點或立場。如有關于作品內容、版權或其它問題請于作品發表后的30日內與ESG跨境電商聯系。
二維碼加載中...
使用微信掃一掃登錄
使用賬號密碼登錄
平臺顧問
微信掃一掃
馬上聯系在線顧問
小程序
ESG跨境小程序
手機入駐更便捷
返回頂部