-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Join the DAL as a Weeklynet baker (#271)
* Add a tutorial to run the DAL as a baker on Weeklynet * Update docs/tutorials/running-the-dal-as-a-weeklynet-baker-in-5-steps/get-octez.md * Apply suggestions from code review * Update docs/tutorials/running-the-dal-as-a-weeklynet-baker-in-5-steps.md rewrite first para as doc not blog * Apply suggestions from code review rewrite warning for updates * Update docs/tutorials/running-the-dal-as-a-weeklynet-baker-in-5-steps.md * Fix compilation * Typo suggested by iguerNL * Typo suggested by German capitalize "Smart Rollup" * Suggestion from German * Suggestion from German * Suggestion from German Co-authored-by: Germán Delbianco <[email protected]> * Suggestion Co-authored-by: Germán Delbianco <[email protected]> * Update docs/tutorials/running-the-dal-as-a-weeklynet-baker-in-5-steps/run-dal-node.md Co-authored-by: NicNomadic <[email protected]> * Suggestion * Suggestion * Don't call for testers The docs.tezos.com website is not a good place to call for action; this should be published as a mere tutorial and linked from blog or agora posts which call for action. * Apply suggestions from Tim Co-authored-by: Tim McMackin <[email protected]> * Be more precise about the time taken to get rights * Simplify intro * Intro: don't mention accusation * Consistent naming of ENDPOINT with the other DAL tutorial * Change title and shorten paths * Replace &>> with >> 2>&1 The latter is more portable * Clarify that the RPC for DAL rights gives all the rights * Split a long sentence * Typo * Typo * Typo * Example of commands to start the Docker image and configure Octez node * use the DAL port * typo * Example of endpoint * admonitions * send output correctly * send output correctly * headings * send output correctly * "$HOME/octez-dal-node.log" Co-authored-by: Raphaël Cauderlier <[email protected]> * "$HOME/octez-accuser.log" Co-authored-by: Raphaël Cauderlier <[email protected]> * "$HOME/octez-baker.log" Co-authored-by: Raphaël Cauderlier <[email protected]> * we can launch it and make its RPC available: Co-authored-by: Raphaël Cauderlier <[email protected]> * For example, for the Weeklynet launched on January 17 2024, the endpoint was: Co-authored-by: Raphaël Cauderlier <[email protected]> * for the Weeklynet launched on January 17 2024, the instructions were: Co-authored-by: Raphaël Cauderlier <[email protected]> --------- Co-authored-by: Raphaël Cauderlier <[email protected]> Co-authored-by: NicNomadic <[email protected]> Co-authored-by: Raphaël Cauderlier <[email protected]> Co-authored-by: Germán Delbianco <[email protected]>
- Loading branch information
1 parent
c1b310f
commit fbe0830
Showing
9 changed files
with
190 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# How to join the Tezos DAL as a baker, in 5 steps | ||
|
||
Tezos' [Data-Availability Layer](https://tezos.gitlab.io/shell/dal.html) (DAL for short), is an experimental feature which is, at the time of writing, not available on Tezos Mainnet but planned to be proposed in a protocol amendment in the near future. | ||
|
||
The DAL is a key component for the scalability of Tezos. In a nutshell, the DAL is about increasing the data bandwidth available for Tezos Smart Rollups thanks to a new parallel P2P network on which rollups could connect to fetch inputs without compromising their security. | ||
|
||
In order for the DAL to be as secure as the Tezos Layer 1 itself, bakers need to play a very important role in it. Currently, bakers on the L1 network are not only responsible for producing blocks but also for attesting that blocks are published on the L1 network. They are rewarded for this contribution through protocol incentives. Similarly, the role of bakers in the DAL would be to attest the publication of data on the DAL's P2P network. They would in turn be rewarded for this through (potentially different) protocol incentives. | ||
|
||
Given that setting up a new P2P network with several hundred active participants may take some time, the first proposed version of the DAL for Tezos Mainnet will not provide any participation incentives. This will let plenty of time for bakers to join the DAL network without risking any reward loss, ensuring a smooth transition. | ||
|
||
This incentive-free version of the DAL is already available on the Weeklynet test network. In this tutorial you will learn how to join Weeklynet as a baker and attest the publication of data on the DAL network. | ||
|
||
:::warning | ||
This tutorial uses a very simple setup running all required daemons on the same machine. In a production environment, we advise against running a DAL attester node under the same IP address than a baker's node because the DAL node may leak the IP address and ease DOS attacks on the baker. See also [the DAL documentation page on baking](https://tezos.gitlab.io/shell/dal_bakers.html). | ||
::: | ||
|
||
:::warning | ||
The UX of the DAL components will be subject to changes with the feedback from the testers following this tutorial, so this tutorial will be updated accordingly. Feel free to file issues if it's not up-to-date. | ||
::: | ||
|
||
- [Step 1: get a Weeklynet-compatible Octez version](./join-dal-baker/get-octez) | ||
- [Step 2: run an Octez node on Weeklynet](./join-dal-baker/run-node) | ||
- [Step 3: setting up a baker account on Weeklynet](./join-dal-baker/prepare-account) | ||
- [Step 4: run an Octez DAL node on Weeklynet](./join-dal-baker/run-dal-node) | ||
- [Step 5: run an Octez baking daemon on Weeklynet](./join-dal-baker/run-baker) | ||
- [Conclusion](./join-dal-baker/conclusion) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# Conclusion | ||
|
||
In this tutorial we have gone through all the steps needed to participate in the Weeklynet test network as a baker and DAL attester. We could further improve the setup by defining system services so that the daemons are automatically launched when the machine starts or when the network restarts on Wednesday. We could also plug a monitoring solution such as the Prometheus + Grafana combo; a Grafana dashboard template for DAL nodes is available in Grafazos. The interactions between our baker and the Weeklynet chain can be observed on the Explorus block explorer which is aware of the DAL and can in particular display which DAL slots are being used at each level. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# Step 1: Get a Weeklynet-compatible Octez version | ||
|
||
The Weeklynet test network is restarted once every Wednesday at 0h UTC, and for most of its lifetime (from level 512) it runs a development version of the Tezos protocol, called Alpha, which is not part of any released version of Octez. For this reason, baking on Weeklynet requires to run Octez either with Docker using a specific Docker image, or by building it from source using a specific git commit. | ||
|
||
To get this specific Docker image, or the hash of this specific commit, see https://teztnets.com/weeklynet-about. This page also contains the proper `octez-node config init` incantation to configure the Octez node with the current network parameters of Weeklynet, the URL of a public RPC endpoint, and a link to a faucet distributing free testnet tez. | ||
|
||
For example, the commands to start a Docker image and configure the Octez node for the Weeklynet launched on January 17 2024, the instructions were: | ||
|
||
``` | ||
docker run -it --entrypoint=/bin/sh tezos/tezos:master_7f3bfc90_20240116181914 | ||
octez-node config init --network https://teztnets.com/weeklynet-2024-01-17 | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
# Step 3: Set up a baker account on Weeklynet | ||
|
||
Our baker needs an implicit account consisting of a pair of keys and an address. The simplest way to get them is to ask the Octez client to randomly generate them and associate them to the `my_baker` alias: | ||
|
||
``` | ||
octez-client gen keys my_baker | ||
``` | ||
|
||
The address of the generated account can be obtained with the following command: | ||
|
||
``` | ||
octez-client show address my_baker | ||
``` | ||
|
||
Let's record this address in a shell variable, this will be useful for the some commands which cannot get addresses by their octez-client aliases. | ||
|
||
``` | ||
MY_BAKER="$(octez-client show address my_baker | head -n 1 | cut -d ' ' -f 2)" | ||
``` | ||
|
||
At this point, the balance of the `my_baker` account is still empty as can be seen with the following command: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" get balance for my_baker | ||
``` | ||
|
||
In order to get some consensus and DAL rights, we need to put some tez on the account. Fortunately, getting free testnet tez is easy thanks to the testnet faucet. To use it, we need to enter the generated address in the Weeklynet faucet linked from https://teztnets.com/weeklynet-about. We need at least 6k tez for running a baker but the more tez we have the more rights we will get and the shorter we will have to wait to produce blocks and attestations; that being said, baking with too much stake would prevent us from leaving the network without disturbing or even halting it so to avoid breaking the network for all other testers let's not be too greedy. 50k tez should be enough to get enough rights to easily check if our baker behaves as expected while not much disturbing the network when our baker will stop operating. | ||
|
||
Once the tez are obtained from the faucet, we can check with the same `get balance` command that they have been received: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" get balance for my_baker | ||
``` | ||
|
||
At this point, the `my_baker` account owns enough stake to bake but has still no consensus nor DAL rights because we haven't declared to the Tezos protocol our intention to become a baker. This can be achieved with the following command: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" register key my_baker as delegate | ||
``` | ||
|
||
Seven cycles later (about 1h40 on Weeklynet), our baker will start receiving rights. To see for instance its consensus attestation rights in the current cycle, we can use the following RPC: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" rpc get /chains/main/blocks/head/helpers/attestation_rights\?delegate="$MY_BAKER" | ||
``` | ||
|
||
To see the DAL attestation rights of all bakers, we can use the following RPC: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" rpc get /chains/main/blocks/head/context/dal/shards | ||
``` | ||
|
||
This command returns an array of DAL attestation rights. The 2048 shards which are expected to be attested at this level are shared between active bakers proportionally to their stake. Each baker is assigned a slice of shard indices represented in the output of this command by a pair consisting of the first index and the length of the slice. So to check if some rights were assigned to us we can filter the array to our baker by running this command: | ||
|
||
``` | ||
octez-client --endpoint "$ENDPOINT" rpc get /chains/main/blocks/head/context/dal/shards | grep "$MY_BAKER" | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# Step 5: Run an Octez baking daemon on Weeklynet | ||
|
||
The baking daemon is launched almost as usual, the only difference is that we use the `--dal-node http://127.0.0.1` option to tell it to connect to the DAL node that we just launched in the previous step. | ||
|
||
``` | ||
octez-baker-alpha run with local node "$HOME/.tezos-node" my_baker --liquidity-baking-toggle-vote on --adaptive-issuance-vote on --dal-node http://127.0.0.1 >> "$HOME/octez-baker.log" 2>&1 | ||
``` | ||
|
||
We can check that the DAL is now subscribed to the relevant topics by retrying the following RPC, which should now return all the topics of the form `{"slot_index":<index>,"pkh":"<ADDRESS OF OUR BAKER>"}` where `index` varies between `0` included and the number of slot indexes (`32` on Weeklynet) exluded: | ||
|
||
``` | ||
curl http://localhost:10732/p2p/gossipsub/topics | ||
``` | ||
|
||
We can also look at the baker logs to see if it manages to inject the expected operations. At each level, the baker is expected to: | ||
- receive a block proposal (log message: "received new proposal ... at level ..., round ...") | ||
- inject a preattestation for it (log message: "injected preattestation ... for my_baker (<address>) for level ..., round ...") | ||
- receive a block (log message: "received new head ... at level ..., round ...") | ||
- inject an attestation for it (log message: "injected attestation ... for my_baker (<address>) for level ..., round ...") | ||
- inject a DAL attestation indicating which of the shards assigned to the baker have been seen on the DAL network (log message: "injected DAL attestation ... for level ..., round ..., with bitset ... for my_baker (<address>) to attest slots published at level ..."); if no shard was seen (either because they did not reach the DAL node for some reason or simply because nothing was published on the DAL at the targetted level), the operation is skipped (log message: "Skipping the injection of the DAL attestation for attestation level ..., round ..., as currently no slot published at level ... is attestable.") | ||
|
||
Optionally, we can also launch an accuser which will monitor the behaviour of the other Weeklynet bakers and denounce them to the Tezos protocol if they are caught double-signing any block or consensus operation. | ||
|
||
``` | ||
octez-accuser-alpha run >> "$HOME/octez-accuser.log" 2>&1 | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# Step 4: Run an Octez DAL node on Weeklynet | ||
|
||
``` | ||
octez-dal-node run >> "$HOME/octez-dal-node.log" 2>&1 | ||
``` | ||
|
||
This, too, may take some time to launch the first time because it needs to generate a new identity file, this time for the DAL network. | ||
|
||
When running normally, the logs of the DAL node should contain one line per block applied by the layer 1 node looking like: | ||
|
||
``` | ||
<timestamp>: layer 1 node's block at level <level>, round <round> is final | ||
``` | ||
|
||
The DAL node we have launched connects to the DAL network but it is not yet subscribed to any Gossipsub topic. We can observe this by requesting the topics it registered to, using the following RPC: | ||
|
||
``` | ||
curl http://localhost:10732/p2p/gossipsub/topics | ||
``` | ||
|
||
In particular, it won't collect the shards assigned to our baker until it is subscribed to the corresponding topics. Don't worry, the baker daemon will automatically ask the DAL to subscribe to the relevant topics. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# Step 2: Run an Octez node on Weeklynet | ||
|
||
Once the Octez node has been configured to join Weeklynet, we can launch it and make its RPC available: | ||
|
||
``` | ||
octez-node run --rpc-addr 127.0.0.1:8732 --log-output="$HOME/octez-node.log" | ||
``` | ||
|
||
At first launch, the node will generate a fresh identity file used to identify itself on the Weeklynet L1 network, it then bootstraps the chain which means that it downloads and applies all the blocks. This takes a variable amount of time depending on when during the week these instructions are followed but at worse, on a tuesday evening, it takes a few hours. Fortunately, we can continue to set up our Weeklynet baking infrastructure while the node is bootstrapping, all we have to do for this is to use another, already bootstrapped, node as RPC endpoint for `octez-client` when we want to interact with the chain. | ||
|
||
A public RPC endpoint URL for Weeklynet is linked from the https://teztnets.com/weeklynet-about page, let's record it in a shell variable: | ||
``` | ||
ENDPOINT="<URL of the RPC endpoint linked from https://teztnets.com/weeklynet-about>" | ||
``` | ||
|
||
For example, for the Weeklynet launched on January 17 2024, the endpoint was: | ||
|
||
``` | ||
ENDPOINT=https://rpc.weeklynet-2024-01-17.teztnets.com | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters