Running an Etherlink Smart Rollup node
Etherlink uses Smart Rollup nodes as a bridge between the EVM transactions on the EVM nodes and Tezos layer 1. Public Smart Rollup nodes for Etherlink are not yet available, so you must run your own if you want to participate in the Etherlink network.
In this context, an Etherlink Smart Rollup node is an Octez Smart Rollup node that runs the Etherlink kernel. This kernel is a Rust program compiled in WASM implementing the semantics of Etherlink blocks and transactions.
To start, the node uses the installer kernel, which is a compressed version of the kernel that provides only enough information to install the original kernel. The data for the original kernel is stored in separate files called preimages.
You can run the Smart Rollup node starting from Etherlink genesis or from a snapshot of a recent Etherlink state.
System requirements
Running an Etherlink Smart Rollup node on Etherlink Mainnet requires a computer with 500GB of disk space and at least 16GB RAM.
Modes
Running the Smart Rollup node in operator or maintenance mode is the best way to participate in Etherlink because in these modes the node posts commitments about Etherlink's state to layer 1. These commitments validate Etherlink's state and ensure that Etherlink is processing blocks and transactions honestly according to its kernel. As described in Smart Rollups on docs.tezos.com, one honest node is enough to ensure that Etherlink is running correctly, but adding more nodes strengthens its security and allows users to verify for themselves that Etherlink is running as intended.
The best way to run a node that can post commitments is to start with a node in observer mode, verify that it works, and convert it to maintenance mode. Maintenance mode is similar to operator mode but it does not require settings for batching operations, which are required only for sequencer nodes.
For more information on modes, see Smart Rollup node in the Octez documentation.
References
Make sure that you understand the interaction between different nodes as described in Etherlink architecture.
For more information about Smart Rollup nodes in general, see Smart Rollups on docs.tezos.com and Smart Rollup Node in the Octez documentation.
Starting the Smart Rollup node in observer mode
You can start the Smart Rollup node in observer mode to bootstrap it and make sure that it works before you change to maintenance mode.
To bootstrap a Smart Rollup node from a snapshot, you need a node that has the full history from the time the snapshot was taken to the current level. Usually this means connecting to an archive node, but if the snapshot is recent, it can work with a rolling node that keeps enough history. After the node has started, you can switch to a rolling node.
Follow these steps to start the node in observer mode:
-
Get a built version of the Smart Rollup node binary, named
octez-smart-rollup-node
. The best place to get the most recent binary files to use with Etherlink is https://gitlab.com/tezos/tezos/-/releases. -
Initialize the local context of the node, which is where it stores local data:
-
Set the environment variable
SR_DATA_DIR
to the directory where the node should store its local data. The default value is$HOME/.tezos-smart-rollup-node
. -
Initialize the local context by running this command and passing the address of the Etherlink Smart Rollup and the preimages endpoint. You can get this information on the Network information page.
For example, this command initializes the context for Etherlink Mainnet:
octez-smart-rollup-node init observer config for sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf \
with operators --data-dir $SR_DATA_DIR \
--pre-images-endpoint https://snapshots.eu.tzinit.org/etherlink-mainnet/wasm_2_0_0For Etherlink testnet, use this command:
octez-smart-rollup-node init observer config for sr18wx6ezkeRjt1SZSeZ2UQzQN3Uc3YLMLqg \
with operators --data-dir $SR_DATA_DIR \
--pre-images-endpoint https://snapshots.eu.tzinit.org/etherlink-ghostnet/wasm_2_0_0This command generates a minimal configuration file (
config.json
) in the local data folder:{ "smart-rollup-address": "sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf",
"smart-rollup-node-operator": {}, "fee-parameters": {}, "mode": "observer",
"pre-images-endpoint":
"https://snapshots.eu.tzinit.org/etherlink-mainnet/wasm_2_0_0" }This configuration uses the preimages that the Tezos Foundation hosts on a file server on a so-called "preimages endpoint". It's safe to use these preimages because the node verifies them. If you don't want to use third-party preimages, you can build the kernel yourself and move the contents of the
wasm_2_0_0/
directory to the local data directory; see Building the Etherlink kernel. However, in this case, you must manually update this directory with the preimages of every kernel voted by the community and deployed on Etherlink after that.
-
-
To speed up the setup process by loading a snapshot, follow these steps:
-
Download the latest snapshot. Mainnet snapshots are available at https://snapshots.eu.tzinit.org/etherlink-mainnet and Testnet snapshots are available at https://snapshots.eu.tzinit.org/etherlink-ghostnet.
For example, this command downloads the latest snapshot for Etherlink mainnet:
wget https://snapshots.eu.tzinit.org/etherlink-mainnet/eth-mainnet.full
-
Load the snapshot by running the
snapshot import
command:octez-smart-rollup-node --endpoint https://rpc.tzkt.io/mainnet \
snapshot import eth-mainnet.full \
--data-dir $SR_DATA_DIR
-
-
Start the Smart Rollup node in observer mode with the
run
command:octez-smart-rollup-node --endpoint https://rpc.tzkt.io/mainnet run \
--data-dir $SR_DATA_DIRIf you did not load a snapshot, the process of starting the node from genesis can take a long time because it must process every block.
If you loaded a snapshot, the node must process every block that has been created since the snapshot was taken, which takes time depending on the age of the snapshot.
By default, the node runs in archive mode. To run in full mode, which stores only the minimal data since the genesis required to reconstruct the ledger state, pass the argument
--history-mode full
. -
Verify that the Smart Rollup node is running by querying it. For example, this query gets the health of the node:
curl -s http://localhost:8932/health
If the response includes the fields
healthy: false
and theblocks_late
field is more than 0, the node is catching up to the current state of Etherlink.{
"healthy": false,
"degraded": false,
"l1": {
"connection": "connected",
"blocks_late": 6949,
"last_seen_head": {
"hash": "BKmkbnFPsmQ28m4Wnsp3wgzvQnDeA9usqqfAFTsXieVGGJVEjS3",
"level": 9253862,
"timestamp": "2024-11-26T15:21:59Z"
}
},
"active_workers": []
} -
Wait until the response includes the field
healthy: true
and theblocks_late
field is 0.
Now the Smart Rollup node is running and tracking the state of Etherlink by receiving information from layer 1.
Converting the Smart Rollup node to maintenance mode
Converting the observer node to maintenance mode requires these prerequisites:
-
Your own Tezos layer 1 node running in any mode.
To run the Smart Rollup node in a mode that posts commitments, including maintenance mode and operator mode, you must connect it to a layer 1 node that you control. Using a public layer 1 node as the basis for a Smart Rollup node in maintenance or operator mode exposes the Smart Rollup node to security risks. For example, a malicious layer 1 node can expose the Smart Rollup node to an incorrect branch, which can cause the Smart Rollup node to post invalid commitments and lose tez when other node operators computing from the correct branch refute them.
As these steps describe, it is safe to bootstrap a node in observer mode by connecting it to a public node, connect it to a layer 1 node that you control, and then switch to maintenance or operator mode.
-
An account with at least 10,000 liquid, available tez, referred to as the operator account. You can use the same account that you use for a layer 1 baker, but for better security, you can use a different account and delegate its tez to the layer 1 account. Without 10,000 liquid tez, the Smart Rollup node will not start in operator or maintenance mode.
-
An account with a small amount of liquid tez for cementing and outbox operations.
Follow these steps to convert a Smart Rollup node from observer mode to maintenance mode:
-
Set up the two accounts in the Octez client.
-
Stop the Smart Rollup node.
-
Restart the node with the layer 1 node that you control, represented in this example by the variable
$MY_LAYER_1_NODE
:octez-smart-rollup-node --endpoint $MY_LAYER_1_NODE run \
--data-dir $SR_DATA_DIR -
Verify that the node continues to run as expected in observer mode.
-
Stop the node.
-
Run the node in maintenance mode, passing the addresses or Octez aliases of the accounts and the layer 1 node that you control.
The first address after
with operators
is the default address that the node uses for operations. You can use different accounts for specific operations by adding the operation and the address to the command. This example uses$OPERATOR_ACCOUNT
for the account with 10,000 liquid tez and$SECONDARY_ACCOUNT
for cementing operations and executing outbox operations:octez-smart-rollup-node run maintenance for sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf \
with operators $OPERATOR_ACCOUNT \
cementing:$SECONDARY_ACCOUNT \
executing_outbox:$SECONDARY_ACCOUNT \
--endpoint $MY_LAYER_1_NODE \
--rpc-addr 0.0.0.0 \
--data-dir $SR_DATA_DIR \
--pre-images-endpoint https://snapshots.eu.tzinit.org/etherlink-mainnet/wasm_2_0_0 -
Verify that the Smart Rollup node is running by querying it. For example, this query gets the health of the node:
curl -s http://localhost:8932/health
Now that you have a Smart Rollup node configured for Etherlink, you can run an Etherlink EVM node, as described in Running an Etherlink EVM node.
Stopping the Smart Rollup node
When you want to stop running the Smart Rollup node, you must wait for the last commitment that your node made to be cemented if you had any. Then you can recover the node's bonded tez and stop the node.
If you stop the node before waiting for its last commitment to be cemented, the bonded tez is at risk if other nodes challenge that commitment and your node is not online to defend it in the Smart Rollup refutation game. For more information, see Smart Rollups on docs.tezos.com.
Follow these steps to stop an Etherlink Smart Rollup node:
-
Stop the node temporarily.
-
Restart the node in
bailout
mode. A node running inbailout
mode defends its existing commitments but does not make new commitments.octez-smart-rollup-node run bailout for sr1Ghq66tYK9y3r8CC1Tf8i8m5nxh8nTvZEf \
with operators $OPERATOR_ACCOUNT \
--endpoint $MY_LAYER_1_NODE \
--rpc-addr 0.0.0.0 \
--data-dir $SR_DATA_DIR \
--pre-images-endpoint https://snapshots.eu.tzinit.org/etherlink-mainnet/wasm_2_0_0 -
Keep the node running for two weeks for the node's last commitment to be cemented.
-
When the last commitment is cemented, the node automatically recovers the bonded tez and shuts down.
Now the node has stopped and the bonded tez is liquid.
If you want to recover the bond manually, use this command:
octez-client recover bond of $BONDED_ACCOUNT for smart rollup $SMART_ROLLUP_ADDRESS from $MY_ACCOUNT
This command uses these arguments:
BONDED_ACCOUNT
: The account that you used to run the Smart Rollup in operator modeSMART_ROLLUP_ADDRESS
: The address of the Etherlink Smart RollupMY_ACCOUNT
: The account to use to send thisrecover bond
operation