作者:Storm Slivkoff, Georgios Konstantopoulos;編譯:深潮 TechFlow
介紹
負載測試是構建開發彈性高、性能優秀數據系統的關鍵步驟。然而,負載測試在加密貨幣基礎設施開發中并沒有得到廣泛應用。我們非常高興地引入了 Flood,這是一款專門針對 RPC 端點性能分析的基準測試工具,以填補這一空白。
最初,我們將 Flood 作為一種工具來優化 Reth,并了解其在不同負載下的延遲和吞吐量權衡。后來,我們發現除了 Reth 之外,Flood 在優化許多類型的加密貨幣基礎設施性能方面具有重要的實用價值。
讓我們一起看看吧。
負載測試是指測量系統受不同工作負載影響時性能特征的變化。這種方法背后的關鍵見解是,當系統承受越來越多的負載時,吞吐量、延遲和錯誤率等性能指標通常會降低。因此,觀察系統在不同控制負載下的表現可以揭示系統瓶頸、故障模式和最終性能容量等信息。
DAO平臺DAOLens獲得500萬美元融資 Nexus Venture Partners領投:金色財經報道,DAO平臺初創公司DAOLens最近在由Nexus Venture Partners領投的種子期前融資500萬美元。專注于加密貨幣的投資公司Better Ventures和iSeed II也共同領投了這輪融資。該平臺隨后的估值并未披露。
在種子輪前的其他數十名參與者中,包括曾供職于Coinbase和a16z的巴拉吉?斯里尼瓦桑;Matrix Partners的庫馬爾?阿卡什;Solana的Raj Gokal;SIG的Dean Carlson;Animoca Brands的Simon Doherty;以及Coinbase和軟銀等公司的高管。
這家初創公司由Vikram Aditya和Apoorv Nandan于今年1月創立。(blockworks)[2022/7/14 2:11:35]
通過負載測試獲得的信息可以用于許多方面。當系統正在開發時,負載測試可以突出顯示哪些系統瓶頸需要優先改進。當比較兩個系統時,負載測試可以揭示哪個系統更具性能或可靠性。作為其中一種特殊情況,負載測試可以比較單個系統的兩個不同硬件或軟件配置。在每種情況下,負載測試都可以實現高度優化的系統開發。
Arbitrum One已完全集成DeFi平臺Parsec:12月11日消息,DeFi平臺Parsec宣布,Arbitrum One已經完全集成Parsec,其Uniswap V3 Analytics現在完全兼容Arbitrum部署。[2021/12/11 7:32:29]
我們的重點是 RPC,這是通常用于從區塊鏈節點提取數據的通信協議。
目前,衡量 RPC 性能最常見的方法不是負載測試,而是延遲測試:您向 RPC 節點發送一個請求,并測量獲得響應所需的時間。各種 RPC 提供商的延遲測試可以在各個網站上找到。不幸的是,這種類型的測試對節點性能提供了有限的視圖,因為它幾乎沒有揭示系統在負載下的行為。
在區塊鏈中,工作負載可以通過兩種重要方式變化。經典的變量是大小。每秒 10,000 個請求的負載對系統的壓力比每秒 100 個請求的負載更大。另一個負載變量是 RPC 方法。對于從區塊鏈節點中提取的每種類型的數據,都有不同的 RPC 方法。例如,塊 vs 事務 vs 日志 vs 蹤跡。每個 RPC 方法對系統施加不同類型的負載。一些 RPC 方法受存儲 IO 限制,而其他方法受 CPU 限制。
ParaFi Capital合伙人公開DeFi市場投資戰略:ParaFi Capital合伙人Santiago Roel Santos透露了該公司在新興的去中心化金融(DeFi)市場進行投資的戰略。他指出其在項目中尋找兩個標準,首先該項目要對產品市場有很強的適應性和吸引力,另一個影響ParaFi投資的因素是實時的鏈上分析。(TheDailyHodl)[2021/1/19 16:28:41]
我們根據這些原則開發了一個負載測試工具,稱為 Flood。與延遲測試不同,Flood 通過負載測試以及擴展測試覆蓋范圍到所有相關的 RPC 方法,為 RPC 端點的性能特征提供了前所未有的視圖。
動態 | 獲得 Paradigm 和紅杉投資的預測市場平臺 Veil 決定停止運營:推出僅僅半年的明星 DeFi 項目 Veil 決定停止運營。Veil 是一個點對點預測市場及衍生品交易平臺,用戶可以通過登陸以太坊錢包參與預測市場及衍生品的相關交易,獲得了 Paradigm、紅杉和 1confirmation 等知名風險投資機構的支持,在今年 1 月份上線。Veil 聯合創始人兼首席執行官 Paul Fletcher-Hill 表示,將不會在 Veil 增加新的交易市場,目前平臺上已有的交易市場將在 7 月 24 日下架。他說,這是個艱難決定,但是該團隊無法實現讓自己的產品適合已經存在的市場,因為目前用戶社區太小。Veil 同時決定,將把自己的交易市場創建工具開源供其他開發者使用。[2019/7/12]
Flood 由三個基本組件組成:
動態 | 投資公司SparkLabs將推出網絡安全和區塊鏈加速計劃:據Techcrunch消息,投資公司SparkLabs已經在亞太地區開展了加速器項目,現在它已經宣布了第一個基于美國土地的加速器計劃,它將是一個網絡安全和區塊鏈計劃,將于明年在華盛頓特區開展。[2018/9/20]
調用生成引擎:Flood 生成大量參數化的 RPC 調用集,隨機采樣分布類似于不同類型的區塊鏈工作負載。Flood 利用 Paradigm Data Portal 數據集確保完全覆蓋區塊鏈歷史。
負載測試引擎:然后,Flood 編排 Vegeta(用 Go 編寫的高性能負載測試工具)使用這些調用進行對 RPC 端點的負載測試。
報告引擎:Flood 在執行測試后,使用各種圖表、表格和報告總結結果。這些摘要易于集成到腳本和數據中。
每個組件都可以高度配置,使 Flood 能夠涵蓋廣泛的測試場景和環境。
在 Flood 的常規操作過程中,用戶指定要測試的 RPC 方法以及 RPC 端點列表。例如,您可能想測試 Reth 的兩個版本的 eth_getLogs 的性能。Flood 將運行不同的控制負載來測試這些 RPC 端點。例如,它可能以每秒 1,000、2,000、4,000 和 8,000 個請求的速度運行 eth_getLogs。Flood 然后將顯示表格和圖表,總結性能指標如何隨負載變化。輸出看起來像這樣:
在負載下性能指標降級的特定方式提供了豐富的見解,可揭示系統瓶頸和最終性能容量。
除此之外,Flood 還提供了高級功能,以適應各種類型的高級用戶:
Flood 可以使用不同的負載測試計劃,包括:“壓力測試”(隨著時間的推移逐漸增加負載),“峰值測試”(大量突然的負載,然后是小負載)和“浸泡測試”(長時間運行負載)。
Flood 可以編排負載測試在每個 RPC 節點上原生模式運行,以消除由網絡瓶頸引起的噪聲。
Flood 具有“相等性”測試模式,可檢查每個 RPC 端點是否返回相同的響應。
在 Paradigm,我們正在開發一種名為 Reth 的新節點實現,性能是其主要目標之一。我們開發了 Flood 來詳細描述 Reth 的性能特征。我們已經使用 Flood 揭示了在各種工作負載和系統配置下出現的眾多 Reth 性能瓶頸。然后,解決了這些瓶頸。通過 Flood,我們創建了一個緊密的反饋循環,使 Reth 開發人員可以高度可見地了解任何代碼庫更改如何轉化為端到端系統性能。
除了 Reth 之外,我們認為 Flood 將能夠幫助解決許多與 RPC 節點有關的未解答的問題:
當運行節點時,哪些硬件規格最重要?存儲 IO 相對于 RAM 速度、RAM 容量和 CPU 速度的重要性如何?RAID 值得嗎?
每個第三方 RPC 提供商的每個 RPC 方法的有效速率限制是多少?
哪個節點客戶端為不同類型的工作負載提供最佳性能?
在本文中,主要介紹了 Flood,一種負載測試工具,它為區塊鏈節點的性能特征提供了前所未有的視圖。雖然最初構建 Flood 是為了優化 Reth 的開發,但我們認為它將成為其他類型的高性能加密貨幣基礎設施開發的重要工具。我們期待看到其他人如何使用 Flood 來構建自己的高性能、可靠的系統。
深潮TechFlow
個人專欄
閱讀更多
金色早8點
Odaily星球日報
金色財經
Block unicorn
DAOrayaki
曼昆區塊鏈法律
撰文:Miles Jennings、 Brian Quintenz,分別為 a16z crypto 總法律顧問和 a16z crypto 全球政策主管編譯.
1900/1/1 0:00:00作者:Matt Levine 編譯: jk,Odaily 星球日報原文作者Matt Levine是一位負責金融報道的彭博觀點專欄作家.
1900/1/1 0:00:00olychain Capital是一家能讓項目發揮潛能、夢想成真的風險投資公司。他們在2017年投資了MakerDAO和dydx,2018年投資了Starkware.
1900/1/1 0:00:00作者:IGNAS 編譯:深潮 TechFlow在韓國,幾乎沒有人不知道比特幣。2017 年,這個擁有 5000 多萬人口的國家完成了所有比特幣交易的 20%,并且成為以太坊的最大市場.
1900/1/1 0:00:00Pendle 是建立在多鏈上的收益代幣化協議,通過將生息代幣本息分離的方式,讓用戶可以折價購買相應的底層資產.
1900/1/1 0:00:00作者:W3C DAO Web3是一個去中心化的網絡,它利用區塊鏈、加密貨幣、NFT和DeFi等技術,為用戶提供更多的自由、隱私和創新.
1900/1/1 0:00:00