Solana Web3.js 2.x版本發布:功能拆分與性能優化

Solana Web3.js 2.x 版本:功能拆分與性能優化

Solana Web3.js 作爲一個功能豐富的 JavaScript 庫,在 11 月正式發布了 2.x 版本。相較於 1.x 版本,新版本進行了較大幅度的改變。本文將對其主要變化進行概括。

雖然 2.x 版本剛剛發布,使用量尚未普及,許多廣泛使用的庫也未進行遷移,但了解這些變化對未來的遷移工作將會有所幫助。

Web3 新手系列:現在升級 @solana/web3.js 2.x 開啓函數式編程

版本對比

舊版本的使用相對簡單,僅包含一個 @solana/web3.js 包,所有功能都集中在其中。它基於類的設計,封裝了大量常用操作。例如,Connection 類提供了數十種方法,幾乎涵蓋了開發者所需的所有功能。此外,Solana cookbook 中提供的大量示例代碼也爲開發者提供了便利。

然而,這種設計也帶來了一些問題。盡管開發者實際使用的功能可能只佔很小一部分,但整個代碼庫都會被下載到用戶設備上,由於庫的代碼量較大,這可能會耗費一定時間。

2.x 版本採取了不同的策略。官方團隊將原有代碼庫拆分爲several個較小的模塊,如 @solana/accounts、@solana/codecs、@solana/rpc、@solana/signers、@solana/transactions 等。同時,它放棄了基於類的實現,更多地採用單個函數的方式。這種改變有利於 JavaScript 代碼構建時的優化,未使用的代碼將被刪除,不會被下載到用戶設備上。根據官方文檔統計,使用新版本的 DApp 基本能獲得 30% 的尺寸優化,如果只使用了少量功能,優化比例可能更高。

這種變化對 Solana 團隊的文檔質量提出了更高要求,如何讓開發者快速找到所需功能成爲一個重要課題。目前來看,包名具有較好的語義性,從名稱上就能大致了解它們的用途,這在某種程度上降低了開發者遷移的難度。

由於新版本剛發布不久,許多項目尚未進行遷移。Solana Cookbook 上關於 2.x 版本的示例也相對較少。此外,新版本傾向於使用運行時內置功能(如生成密鑰對),但文檔中對此的描述不足,導致某些地方開發者可能感到困惑。

2.x 版本的另一個重要特點是零依賴。這一點對許多用戶來說可能不那麼重要,但考慮到今年 12 月初發生在 @solana/web3.js 1.95.5 和 1.95.6 版本上的供應鏈攻擊,更多的外部輸入和依賴會大幅增加安全事件發生的可能性。隨着 2.x 版本的發布,Web3.js 的開發團隊決定更多地使用本機功能,取消外部依賴和 Polyfills 的引入。雖然未來可能會有變化,但目前 2.x 版本已經消除了所有外部依賴。

重要變更點

連接

在 1.x 版本中,Connection 類提供了大量方法。其主要功能是通過配置 RPC 請求地址創建一個請求發送器,然後通過它發送各種請求。

2.x 版本採用了更加函數式的方式實現:

javascript import { createSolanaRpc } from "@solana/web3.js";

const rpc = createSolanaRpc("");

當調用 sendAndConfirmTransaction 發送交易時,會自動發起 HTTPS 請求,並建立 WSS 連接訂閱交易狀態,在交易被確認後返回交易 hash。

密鑰對

公鑰和私鑰相關的部分也有較大變化。1.x 版本中常用的 Keypair 和 PublicKey 類不再存在,被一些函數替代。

例如,可以使用 await generateKeyPair() 生成密鑰對,而不是之前的 Keypair.generate()。

新的 generateKeyPair 返回 Promise,這是因爲新實現盡可能利用了 JavaScript 的 Web Crypto API,使用了原生的 Ed25519 實現。Web Crypto API 的許多方法都是異步的。不過,這種變化對於熟悉 Promise 的 JavaScript 開發者來說應該不會造成太大困擾。

發送交易

1.x 版本中常用的 Transaction 和 VersionedTransaction 類在 2.x 版本中不再存在。

舊版本中提供的 System Program 相關方法也不再存在,SystemProgram 類上的靜態方法需要從其他地方引入。

例如,transfer 指令需要調用 @solana-program/system 中的 getTransferSolInstruction 函數。

由於不再提供 class,Web3.js 提供了函數式編程中常用的 pipe 形式。以下是使用 pipe 函數實現原本 1.x 的轉帳功能的示例:

javascript import { pipe } from "@solana/functional"; import { getTransferSolInstruction } from "@solana/system"; import { createSolanaRpc, sendTransaction, setTransactionFeePayer, createTransaction, appendTransactionInstruction, } from "@solana/web3.js";

const rpc = createSolanaRpc("");

const transaction = pipe( createTransaction(), setTransactionFeePayer(payer.address), appendTransactionInstruction( getTransferSolInstruction({ fromAddress: payer.address, toAddress: recipient, amount, }) ) );

const signature = await sendTransaction(rpc, transaction, [payer]);

相比 1.x 版本,代碼量有所增加,但可定制性更強。

交易通過 HTTPS RPC 發起,然後通過訂閱 WSS RPC 來確認交易結果。新的方式對 WSS 的依賴更高,這也對 RPC 供應商的服務穩定性提出了更高要求。

React

@solana/web3.js 項目中還包含了一個名爲 @solana/react 的庫,提供了一些 React Hook,內置了諸如 signIn 等功能。

總結

@solana/web3.js 2.x 版本的發布體現了 Solana 團隊對持續發展和改進的承諾。它爲開發人員提供了一種高效、靈活、可定制的方式與 Solana 網路進行交互,有助於推動該平台的採用和發展。

Web3 新手系列:現在升級 @solana/web3.js 2.x 開啓函數式編程

查看原文
此页面可能包含第三方内容,仅供参考(非陈述/保证),不应被视为 Gate 认可其观点表述,也不得被视为财务或专业建议。详见声明
  • 讚賞
  • 7
  • 分享
留言
0/400
盲盒受害者vip
· 07-10 20:02
什么时候出完第一个项目再说...看累了
回復0
永远在抄底vip
· 07-10 17:13
现在又要搬砖了啊
回復0
airdrop_huntressvip
· 07-10 07:51
升级好快 但这bug能修完吗
回復0
DeFi工程师Jackvip
· 07-10 07:47
*实际上* 模块化并非易事... 性能提升看起来很有前景,但晒给我基准测试吧,老大
查看原文回復0
GateUser-75ee51e7vip
· 07-10 07:44
sol老哥这又是要大升级啊
回復0
SelfCustodyIssuesvip
· 07-10 07:41
什么破优化 又得重写代码了
回復0
胶水君vip
· 07-10 07:28
啊哈升级了还行 去看看坑多不多
回復0
交易,隨時隨地
qrCode
掃碼下載 Gate APP
社群列表
繁體中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)