324 个稳定版本

2.0.7 2024 年 8 月 24 日
2.0.3 2024 年 7 月 20 日
1.18.22 2024 年 8 月 9 日
1.18.20 2024 年 7 月 24 日
1.4.13 2020 年 11 月 29 日

#576 in 魔法豆

Download history 4974/week @ 2024-05-04 5203/week @ 2024-05-11 4809/week @ 2024-05-18 5271/week @ 2024-05-25 5577/week @ 2024-06-01 4498/week @ 2024-06-08 4775/week @ 2024-06-15 7705/week @ 2024-06-22 4924/week @ 2024-06-29 4883/week @ 2024-07-06 5242/week @ 2024-07-13 5547/week @ 2024-07-20 5828/week @ 2024-07-27 6016/week @ 2024-08-03 5924/week @ 2024-08-10 3883/week @ 2024-08-17

22,592 每月下载量
用于 179 个包 (5 个直接使用)

Apache-2.0

1.5MB
31K SLoC

Solana

Solana crate Solana documentation Build status codecov

构建

1. 安装 rustc、cargo 和 rustfmt。

$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt

在构建 master 分支时,请确保您使用的是最新的稳定 rust 版本,通过运行

$ rustup update

在构建特定的发布分支时,您应该在 ci/rust-version.sh 中检查 rust 版本,并在必要时通过运行来安装该版本

$ rustup install VERSION

请注意,如果这不是您机器上最新的 rust 版本,则 cargo 命令可能需要一个 覆盖 来使用正确的版本。

在 Linux 系统上,您可能需要安装 libssl-dev、pkg-config、zlib1g-dev、protobuf 等。

在 Ubuntu 上

$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang cmake make libprotobuf-dev protobuf-compiler

在 Fedora 上

$ sudo dnf install openssl-devel systemd-devel pkg-config zlib-devel llvm clang cmake make protobuf-devel protobuf-compiler perl-core

2. 下载源代码。

$ git clone https://github.com/anza-xyz/agave.git
$ cd agave

3. 构建。

$ ./cargo build

测试

运行测试套件

$ ./cargo test

启动本地测试网

在本地启动您自己的测试网,说明在 在线文档 中。

访问远程开发集群

  • devnet - 可通过 devnet.solana.com 访问的稳定公共集群,用于开发。每天 24 小时运行。了解更多关于 公共集群 的信息

基准测试

首先,安装 rustc 的夜间构建。 cargo bench 需要 unstable 功能,这些功能仅在夜间构建中可用。

$ rustup install nightly

运行基准测试

$ cargo +nightly bench

发布流程

此项目的发布流程在本描述。

代码覆盖率

要生成代码覆盖率统计信息

$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html

为什么需要覆盖率?虽然大多数人将覆盖率视为代码质量指标,但我们将其主要视为开发者生产力指标。当开发人员对代码库进行更改时,这通常被认为是针对某些问题的解决方案。我们的单元测试套件是我们编码代码库解决的一组问题。运行测试套件应表明您的更改没有侵犯其他人的解决方案。添加测试可以保护您的解决方案免受未来更改的影响。比如说您不知道为什么存在一行代码,试着删除它并运行单元测试。最近的测试失败应该会告诉您该代码解决了什么问题。如果没有测试失败,您可以提交一个请求,询问“这段代码解决了什么问题?”另一方面,如果测试失败并且您能想到更好的解决同一问题的方法,您的解决方案请求将非常受欢迎!同样,如果重写测试可以更好地传达它所保护的代码,请将此补丁发送给我们!


lib.rs:

从任意验证者的角度,这是一个账本状态的客户端。

使用start_tcp_client()创建客户端,然后导入BanksClientExt以访问其方法。此外,“*with_context”方法也可用,但它们未记录,可能会随时间改变,并且通常使用起来更繁琐。

依赖关系

约17–27MB
约396K SLoC