Setup
Make sure to first install the prerequisites from the quickstart section before proceeding.
Installation
Before you can start migrating your rollup, you'll need to build and install Kailua's binaries by calling the following commands from the root project directory:
At the cost of longer compilation time, you can embed the RISC Zero zkvm prover logic into kailua-cli instead of
having it utilize your locally installed RISC Zero r0vm for proving.
To do this, add -F prove to the install command below.
For GPU-accelerated local proving, use one of the following feature flags:
- Apple:
-F metal - Nvidia:
-F cuda
CLI Binary
cargo install kailua-cli --path bin/cli --locked
Configuration
Once your installation is successful, you should be able to run the following command to fetch the Kailua configuration parameters for your rollup instance:
kailua-cli config --op-node-url [YOUR_OP_NODE_URL] --op-geth-url [YOUR_OP_GETH_URL] --eth-rpc-url [YOUR_ETH_RPC_URL]
Running the above command against the respective Base mainnet endpoints should produce the following output:
RISC0_VERSION: 3.0.3
KAILUA_FPVM_KONA_ID: 0xFBFE59FCB0AAD87BE48BC07F6EADC8C126E0E0E3989C61B5F943A4ED2F885018
KAILUA_FPVM_KONA_ELF: 9.6 MiB
KAILUA_FPVM_HOKULEA_ID: 0x2D031EF292D38DE0C4E2232C430F8FB4A13ABCCAC8C6ED863BFCB1F0FC28F763
KAILUA_FPVM_HOKULEA_ELF: 10.9 MiB
KAILUA_FPVM_HANA_ID: 0x80D8FFF25F4AC12E9A6E95CC7EE9A1BF19F7921D4D184F5AF1C77E6904625B16
KAILUA_FPVM_HANA_ELF: 10.5 MiB
CONTROL_ROOT: 0xA54DC85AC99F851C92D7C96D7318AF41DBE7C0194EDFCC37EB4D422A998C1F56
CONTROL_ID: 0x04446E66D300EB7FB45C9726BB53C793DDA407A62E9601618BB43C5C14657AC0
RISC_ZERO_VERIFIER: 0x8EAB2D97DFCE405A1692A21B3FF3A172D593D319
GENESIS_TIMESTAMP: 1686789347
BLOCK_TIME: 2
ROLLUP_CONFIG_HASH: 0x7CA43EEBCE431E3D320F762561B4C1F4E31277325F0CC466AA5C16178B76CD8F
DISPUTE_GAME_FACTORY: 0x43EDB88C4B80FDD2ADFF2412A7BEBF9DF42CB40E
OPTIMISM_PORTAL: 0x49048044D57E1C92A77F79988D21FA8FAF74E97E
KAILUA_GAME_TYPE: 1337
Make sure that your FPVM_IMAGE_ID matches the value above.
This value determines the exact program used to prove faults.
If your RISC_ZERO_VERIFIER value is blank, this means that your rollup might be deployed on a base layer that does
not have a deployed RISC Zero zkVM verifier contract.
This means you might have to deploy your own verifier.
Always revise the RISC Zero documentation
to double-check verifier availability.
Once you have these values you'll need to save them for later use during migration.
Telemetry
All Kailua binaries and commands support exporting telemetry data to an
OTLP Collector.
The collector endpoint can be specified using the --otlp-collector parameter, or through specifying the
OTLP_COLLECTOR environment variable.