Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jito-foundation/jito-solana
Jito Foundation MEV Solana Client
https://github.com/jito-foundation/jito-solana
mev solana validator
Last synced: 3 days ago
JSON representation
Jito Foundation MEV Solana Client
- Host: GitHub
- URL: https://github.com/jito-foundation/jito-solana
- Owner: jito-foundation
- License: apache-2.0
- Created: 2022-03-01T00:36:37.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-11-22T19:30:23.000Z (about 2 months ago)
- Last Synced: 2024-11-23T06:43:09.243Z (about 2 months ago)
- Topics: mev, solana, validator
- Language: Rust
- Homepage:
- Size: 347 MB
- Stars: 362
- Watchers: 12
- Forks: 150
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- best-of-crypto - GitHub - 16% open · ⏱️ 27.05.2024): (Others)
README
[![Build status](https://badge.buildkite.com/3a7c88c0f777e1a0fddacc190823565271ae4c251ef78d83a8.svg)](https://buildkite.com/jito/jito-solana)
# About
This repository contains Jito's fork of the Solana validator.
We recommend checking out our [Gitbook](https://jito-foundation.gitbook.io/mev/jito-solana/building-the-software) for
more detailed instructions on building and running Jito-Solana.---
## **1. Install rustc, cargo and rustfmt.**
```bash
$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt
```When building the master branch, please make sure you are using the latest stable rust version by running:
```bash
$ rustup update
```When building a specific release branch, you should check the rust version in `ci/rust-version.sh` and if necessary,
install that version by running:```bash
$ rustup install VERSION
```Note that if this is not the latest rust version on your machine, cargo commands may require
an [override](https://rust-lang.github.io/rustup/overrides.html) in order to use the correct version.On Linux systems you may need to install libssl-dev, pkg-config, zlib1g-dev, protobuf etc.
On Ubuntu:
```bash
$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang cmake make libprotobuf-dev protobuf-compiler
```On Fedora:
```bash
$ sudo dnf install openssl-devel systemd-devel pkg-config zlib-devel llvm clang cmake make protobuf-devel protobuf-compiler perl-core
```## **2. Download the source code.**
```bash
$ git clone https://github.com/jito-foundation/jito-solana.git
$ cd jito-solana
```## **3. Build.**
```bash
$ ./cargo build
```> [!NOTE]
> Note that this builds a debug version that is **not suitable for running a testnet or mainnet validator**. Please read [`docs/src/cli/install.md`](docs/src/cli/install.md#build-from-source) for instructions to build a release version for test and production uses.# Testing
**Run the test suite:**
```bash
$ ./cargo test
```### Starting a local testnet
Start your own testnet locally, instructions are in the [online docs](https://docs.solanalabs.com/clusters/benchmark).
### Accessing the remote development cluster
* `devnet` - stable public cluster for development accessible via
devnet.solana.com. Runs 24/7. Learn more about the [public clusters](https://docs.solanalabs.com/clusters)# Benchmarking
First, install the nightly build of rustc. `cargo bench` requires the use of the
unstable features only available in the nightly build.```bash
$ rustup install nightly
```Run the benchmarks:
```bash
$ cargo +nightly bench
```# Release Process
The release process for this project is described [here](RELEASE.md).
# Code coverage
To generate code coverage statistics:
```bash
$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html
```Why coverage? While most see coverage as a code quality metric, we see it primarily as a developer
productivity metric. When a developer makes a change to the codebase, presumably it's a *solution* to
some problem. Our unit-test suite is how we encode the set of *problems* the codebase solves. Running
the test suite should indicate that your change didn't *infringe* on anyone else's solutions. Adding a
test *protects* your solution from future changes. Say you don't understand why a line of code exists,
try deleting it and running the unit-tests. The nearest test failure should tell you what problem
was solved by that code. If no test fails, go ahead and submit a Pull Request that asks, "what
problem is solved by this code?" On the other hand, if a test does fail and you can think of a
better way to solve the same problem, a Pull Request with your solution would most certainly be
welcome! Likewise, if rewriting a test can better communicate what code it's protecting, please
send us that patch!