本文档是 Solana 项目的更新日志,记录了从 1.17.0 版本到 2.3.0 版本的重要变更,包括破坏性更新、新增功能、命令行参数修改、SDK 更新等,旨在让贡献者、验证者、RPC 运营者和 DApp 开发者了解每个版本引入的关键变化和升级注意事项。
本项目的全部显著变更都将记录在此文件中。
请在进行更改时遵循本文档底部的指南 格式基于 Keep a Changelog。 本项目遵循 语义化版本控制 并遵循 向后兼容性策略
发布渠道有其自身的变更日志副本:
<a name="edge-channel"></a>
--skip-preflight
选项,用于跳过通过 RPC 发送的所有交易的预检检查。此标志与 --use-rpc
一起使用,可以提高使用公共 RPC 节点进行程序部署的成功率。solana feature revoke
,用于撤销挂起的特性激活。当特性被激活时,可以使用 solana feature revoke <feature-keypair> <cluster>
来释放并将账户重新分配给系统程序,从而撤销操作。这只能在特性变为活动状态之前完成。--block-production-method
添加新的变体 central-scheduler-greedy
。这是一个简化的调度器,比更严格的 central-scheduler
变体具有更好的性能。--accounts-db-access-storages-method
,并将默认值更改为 file
banking-trace
目录。如果不清除,不会中断,但该文件将是新/旧格式的混合。(#4043)--snapshot-zstd-compression-level
以设置使用 zstd 归档快照时的压缩级别。--tower-storage
和所有 --etcd-*
参数cargo-build-sbf
:添加 --skip-tools-install
标志以避免下载平台工具,并添加 --no-rustup-override
标志以在调用 cargo
时不使用 rustup。对于像 Nix 这样的不可变环境很有用。--block-production-method central-scheduler-greedy
现在是默认值。cargo-build-bpf
和 cargo-test-bpf
已被弃用两年,现在已完全移除。
请改用 cargo-build-sbf
和 cargo-test-sbf
。curve25519-dalek
升级到新的主要版本 4 (#1693)。这会导致混合使用 v2.0 和 v2.1 Solana crate 时出现中断,因此请确保使用其中一个版本的全部内容。请仅使用与 v2.1 兼容的 crate。redelegate
指令处理器和 CLI 命令 (#2213)&self
而不是 &mut self
(#2591)agave-validator
:--rocksdb-shred-compaction
的已弃用值 fifo
(#3451)respan
宏。这被标记为“仅供内部使用”,并且不再在内部使用。entrypoint_no_alloc!
,这是一个性能更高的程序入口点,可以避免分配,从而为每个唯一帐户节省 20-30 个 CUcargo-build-sbf
:工作区或包级别的 Cargo.toml 可以指定 tools-version
,以便在构建链上程序时覆盖默认平台工具版本。例如:
[package.metadata.solana]
tools-version = "1.43"
或
[workspace.metadata.solana]
tools-version = "1.43"
所选工具版本的优先级顺序为:--tools-version
参数、包版本、工作区版本,最后是默认版本。
package-metadata
:在 Cargo.toml 中指定程序的 id,以便下游用户和使用 solana-package-metadata
的工具轻松使用 (#1806)。例如:
[package.metadata.solana]
program-id = "MyProgram1111111111111111111111111111111111"
可以在程序 crate 中使用:
solana_package_metadata::declare_id_with_package_metadata!("solana.program-id");
这等效于编写:
solana_pubkey::declare_id!("MyProgram1111111111111111111111111111111111");
agave-validator
:更新 PoH 速度检查以与来自 Bank 的当前哈希率进行比较 (#2447)solana-test-validator
:添加 --clone-feature-set
标志以模拟来自目标集群的特性 (#2480)solana-genesis
:--cluster-type
参数现在克隆来自目标集群的特性集 (#2587)unified-scheduler
作为 --block-verification-method
的默认选项 (#2653)--block-production-method
的 thread-local-multi-iterator
选项已弃用 (#3113)Rent
和 EpochSchedule
上派生 Copy
,请切换到使用 clone()
(solana-labs#32767)solana-sdk
:已移除已弃用的符号solana-program
:已移除已弃用的符号RpcClient
和 RpcClient::nonblocking
中移除solana-client
:已移除已弃用的重新导出;请直接导入 solana-connection-cache
、solana-quic-client
或 solana-udp-client
agave-validator
中移除:--enable-rpc-obsolete_v1_7
(#1886)--accounts-db-caching-enabled
(#2063)--accounts-db-index-hashing
(#2063)--no-accounts-db-index-hashing
(#2063)--incremental-snapshots
(#2148)--halt-on-known-validators-accounts-hash-mismatch
(#2157)central-scheduler
作为 --block-production-method
的默认选项 (#34891)solana-rpc-client-api
:RpcFilterError
依赖于 base64
版本 0.22,因此用户可能需要升级到 base64
版本 0.22--health-check-slot-distance
的默认值从 150 更改为 128--with-compute-unit-price
、--max-sign-attempts
和 --use-rpc
simulateTransaction
现在在响应中返回一个额外的 replacementBlockhash
字段,当 replaceRecentBlockhash
配置参数为 true
时 (#380)cargo test-sbf
接受 --tools-version
,就像 build-sbf
一样 (#1359)--full-snapshot-archive-path
(#1631)amountToUiAmount
指令将金额解析为字符串而不是数字 (#1737)epoch_rewards_status
(#1274)--block-verification-method
添加了 unified-scheduler
选项 (#1668)--rocksdb-shred-compaction
的 fifo
选项 (#1882)fifo
将在 v2.0 中保持支持,并计划在 v2.1 中完全移除changelog
标签--use-snapshot-archives-at-startup
的默认值现在为 when-newest
(#33883)solana-ledger-tool
的默认值仍然为 always
(#34228)--block-production-method
添加了 central-scheduler
选项 (#33890)getSignaturesForAddress
始终按块包含顺序返回签名字simulateTransaction
现在将 innerInstructions
作为 json
/jsonParsed
返回 (#34313)。entries
表中--signer
CLI 标志使用多个值,强制用户指定多个 --signer
,每个签名一个solana program extend
进行扩展
才能升级。gossip_service::get_client()
的接口已更改。gossip_service::get_multi_client()
已被移除。--with-compute-unit-price
、--max-sign-attempts
和 --use-rpc
solana-program
和 solana-sdk
默认为支持 Borsh v1,对 v0.10 和 v0.9 具有
有限的向后兼容性。请升级到 Borsh v1。entries
表--use-snapshot-archives-at-startup
以加快验证器重启vx.y+1.0 - Unreleased
Unreleased
注释。vx.y.z
节中删除 Unreleased
注释vx.y.z+1 - Unreleased
- 原文链接: github.com/anza-xyz/agav...
- 登链社区 AI 助手,为大家转译优秀英文文章,如有翻译不通的地方,还请包涵~
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!