Skip to content

Commit

Permalink
update readme
Browse files Browse the repository at this point in the history
  • Loading branch information
MaghnusM committed Oct 8, 2022
1 parent 680b2c9 commit ca1fbbf
Showing 1 changed file with 87 additions and 24 deletions.
111 changes: 87 additions & 24 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,19 +1,13 @@

![](https://s3.us-west-2.amazonaws.com/secure.notion-static.com/33ea763f-bfa3-4c65-ad35-ad0ee1fd312d/Group_6.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=AKIAT73L2G45EIPT3X45%2F20220921%2Fus-west-2%2Fs3%2Faws4_request&X-Amz-Date=20220921T004412Z&X-Amz-Expires=3600&X-Amz-Signature=da5c1352a65fb61d2fc143d8c1293689fe7e1cd21cd834516338f2812d66cf84&X-Amz-SignedHeaders=host&x-id=GetObject)

![banner](https://skip-protocol.notion.site/image/https%3A%2F%2Fs3-us-west-2.amazonaws.com%2Fsecure.notion-static.com%2F33ea763f-bfa3-4c65-ad35-ad0ee1fd312d%2FGroup_6.png?table=block&id=4e75ce44-3f92-482e-a199-4aa75631706b&spaceId=4ee2f125-c8d3-4d79-9a63-1a260c9b8377&width=2000&userId=&cache=v2)

# mev-tendermint


_**The purpose of mev-tendermint is to expose a private mempool (the “sidecar”) containing atomic bundles of txs and gossips bundles of transactions specifically to the proposer of the next block.**_

***The purpose of mev-tendermint is to create a private mempool (the “sidecar”) containing atomic bundles of txs and gossip bundles of transactions specifically to the proposer of the next block.***

---


### Design Goals


The design goals of MEV-Tendermint is to allow & preserve:

1. 🔒  **Privacy** for users submitting bundles
Expand All @@ -23,33 +17,102 @@ The design goals of MEV-Tendermint is to allow & preserve:
5. 🔄  **On-chain transaction submission** via gossip, no need for off-chain submission like HTTP endpoints, endpoint querying, etc
6. 💨  **Impossible to slow down block time**, i.e. no part of mev-tendermint introduces consensus delays

### Components
### Basic Functionality Overview

🏦 **Auction**

- Prior to the creation of the first proposal for height `n+1` , the Skip Sentinel infrastructure selects an auction-winning bundle (or bundles) to include at the top of block `n+1`
- The auction-winning bundle is defined as the bundle that pays the highest gas price ( sum(txFee)/sum(gasWanted) ) and doesn’t include any reverting transactions
- The sentinel ensures it’s simulations of the bundle are accurate by simulating it against the version of state where it will actually run (by optimistically applying the proposals produced for height `n` )

🗣️ **Gossip**

- Before the first proposal for height `n+1` is created, the Skip sentinel gossips the auction-winning bundle(s) to whichever nodes belonging to that proposer it can access (e.g. sentries if the validator is using a sentry configuration, or validator replicas if it’s using horcrux)
- The nodes that receive the winning bundle(s) gossip it to the other nodes belonging to that proposer to ensure the bundle(s) reach the validator
- This selective gossiping is powered by new config options (`personal_peer_ids`) and takes place over a new channel, but it is secured using the same authentication handshake Tendermint uses to secure all other forms of p2p communication

[reinforce that we have different channels on the same reactor]

🏒 **Handling Transactions**

- Ordinary transactions received over traditional gossip are handled exactly the same way they are today in the mempool
- Transactions received as part of bundles sent from the Skip sentinel are handled and stored in a new data structure called the `sidecar`
- These transactions have additional metadata about the bundle in which they should be included (e.g. bundleOrder, bundleSize). The sidecar uses this data to reconstruct bundles as it receives individual transactions over gossip

[reinforce that we have a new transaction data structure]

🚜 **Reaping**

- On reap, mev-tendermint first checks whether there are any fully-constructed bundles in the sidecar then reaps these first.
- Next, it reaps from the ordinary mempool, with some additional checks to ensure that transactions reaped from the sidecar don’t get reaped again if they are also present in the standard mempool

[reinforce reaping of bundle goes to top if available]

### Components

**#1 The Sidecar**

- A separate, private mempool that respects `bundles` of transactions
- Relevant files: `mempool/clist_sidecar.go`
- Relevant files: `mempool/clist_sidecar.go`
- Has **selective gossiping**, meaning it only gossips:
- Over its own `SidecarChannel`
- **Only** to peers that are added as its `personal_peers`
- In practice, `personal_peers` are set to be:
- Sentry node → **validator** & **Skip sentinel**
- Validator node → **only its sentries**
- Over its own `SidecarChannel`
- **Only** to peers that are added as its `personal_peers`
- In practice, `personal_peers` for each node are set to be:
- Sentry node → **Skip sentinel** & **the other nodes you’re running that the sentry is aware of (e.g. validator or a layer of sentries closer to the validator)**
- Validator node → **only its sentries**

**#2 The Mempool Reactor**

- The mempool reactor now supports a `SidecarChannel` over which only gossip for `SidecarTxs` can be handled
- Relevant files: `mempool/reactor.go`
- `SidecarTxs` have new metadata that is transmitted over gossip, including
- `BundleId` - the **global** order of the bundle this `SidecarTx` is in, per height
- `BundleOrder` - the **local** order of this `SidecarTx` within its bundle
- `DesiredHeight` - the height of the bundle this `SidecarTx` was submitted for
- `BundleSize` - the total size of the bundle this `SidecarcarTx` is in
- `TotalFee` - the total fee of the bundle this `SidecarTx` is in
- This metadata is submitted at a transaction level as **tendermint currently is not designed to broadcast batches of transactions**
- Relevant files: `mempool/reactor.go`
- `SidecarTxs` have new metadata that is transmitted over gossip, including
- `BundleId` - the **global** order of the bundle this `SidecarTx` is in, per height
- `BundleOrder` - the **local** order of this `SidecarTx` within its bundle
- `DesiredHeight` - the height of the bundle this `SidecarTx` was submitted for
- `BundleSize` - the total size of the bundle this `SidecarcarTx` is in
- `TotalFee` - the total fee of the bundle this `SidecarTx` is in
- This metadata is submitted at a transaction level as **tendermint currently is not designed to broadcast batches of transactions**

**#3 Selective Reaping**

- The regular mempool now considers `sidecarTxs` (i.e. bundles) in addition to regular txs, and orders the former before the latter
- Relevant files: `mempool/clist_mempool.go`, `state/execution.go`
- Relevant files: `mempool/clist_mempool.go`, `state/execution.go`

# 👨‍💻 How to Configure

### 1. Tendermint replacement ♻️

In the `go.mod` file of the directory you use to compile your chain binary, you need to `replace` the imported version of `tendermint` with the correct `mev-tendermint` version, like so:

- For Juno (testnet and mainnet), this is: `github.com/skip-mev/mev-tendermint/v0.34.21-mev`

```tsx
// ---------------------------------
replace (
// Other stuff...
github.com/tendermint/tendermint => github.com/skip-mev/mev-tendermint v0.34.21-mev
)
```

🚨 **After modifying the `replace` statement, run `go mod tidy` in your base directory**

### 2. Peering Setup 🤝

mev-tendermint introduces a new section of config in `config.toml` called `sidecar`, which contains 2 settings that you must configure in order to receive bundles from the skip sentinel:

- `relayer_id` : This is the Tendermint p2p id of the Skip Sentinel that is used to establish a secret, authenticated handshake between your node and the Skip sentinel
- For nodes that should not communicate with the sentinel directly (e.g. validator nodes that have sentries), this does not need to be set.
- `personal_peer_ids`: These are the Tendermint p2p ids of all the nodes that your node will gossip side car transactions with. To ensure trader privacy, these should only include p2p ids of nodes that you manage.
- For your validator, this should be the `ids` of all your sentry nodes
- For your sentry nodes, this should be the `ids` of all your **other** sentry nodes, and your validator

### 3. Information Skip Requires from you ℹ️

In order to participate in the network, you must share with Skip (feel free to contact us at on our **[website](https://skip.money/)**):

1. The Tendermint Address of your validator (The `“address”` field of the `priv_validator_key.json` file generated by Tendermint)
2. The Tendermint p2p ids of all nodes you wish the Skip sentinel to gossip with directly (Can be obtained by `tendermint show-node-id`

### 4. Recompile your binary, and start! 🎉

That’s it! After making the changes above, you can recompile your binary like `junod` (probably using `make install`), and restart your node(s)! You will now begin receiving MEV bundles from Skip.

0 comments on commit ca1fbbf

Please sign in to comment.