Deploy a Smart Rollup
Estimated time: 90 minutes
This tutorial covers how to deploy a Smart Rollup in a Tezos sandbox. To run this tutorial, you should have a basic understanding of how Tezos works and the ability to use the command-line terminal on your computer.
In this tutorial, you will learn:
- What a Smart Rollup is and how they help scale Tezos
- How information passes between Tezos and Smart Rollups
- How to respond to messages from Tezos in a Smart Rollup
What is a Smart Rollup?
Smart Rollups are processing units that run outside the Tezos network but communicate with Tezos on a regular basis. These processing units can run arbitrarily large amounts of code without waiting for Tezos baking nodes to run and verify that code. Smart Rollups use Tezos for information and transactions but can run large applications at their own speed, independently of the Tezos baking system.
In this way, Smart Rollups allow Tezos to scale to support large, complex applications without slowing Tezos itself or incurring large transaction and storage fees. The processing that runs on Tezos itself via smart contracts is referred to as layer 1 and the processing that Smart Rollups run is referred to as layer 2. To learn about running code in smart contracts, see the tutorial Deploy a smart contract.
Rollups also have an outbox, which consists of calls to smart contracts on layer 1. These calls are how rollups send messages back to layer 1.
Smart Rollups can run any kind of applications that they want, such as:
- Financial applications that use information and transactions from Tezos
- Gaming applications that manipulate assets and keep them in sync with Tezos
- Applications that run complex logic on NFTs or other types of tokens
- Applications that communicate with other blockchains
Rollups maintain consensus by publishing the hash of their state to Tezos, which other nodes can use to verify the rollup's behavior. The specific way that rollups publish their states and maintain consensus is beyond the scope of this tutorial. For more information about rollups and their consensus mechanism, see Smart Optimistic Rollups.
This diagram shows a Smart Rollup interacting with layer 1 by receiving a message, running processing based on that message, and sending a transaction to layer 1:

Smart Rollups stay in sync with Tezos by passing messages to Tezos and receiving messages from Tezos and other rollups. Each Tezos block contains a global rollups inbox that contains messages from Tezos layer 1 to all rollups. Anyone can add a message to this inbox and all messages are visible to all rollups. Rollups receive this inbox, filter it to the messages that they are interested in, and act on them accordingly.
Smart Rollup analogy
Businesses talk about horizontal scaling versus vertical scaling. If a business is growing and its employees are being overworked, the business could use vertical scaling to hire more employees or use better tools to improve the productivity of each employee. Scaling Tezos in this way would mean using more processing power to process each new block, which would increase the cost to run baking nodes. Also, if the business hires more employees, the amount of communication between employees increases because, for example, they have to make sure that they are working in the same way and not doing duplicate jobs.
By contrast, Smart Rollups behave like horizontal scaling. In horizontal scaling, businesses create specialized teams that work on different portions of the workload. These teams can work independently of other teams and take advantage of efficiencies of being focused on a specific task. They also need to communicate less with other teams, which speeds up their work. Smart Rollups are like separate horizontally scaled teams, with Tezos layer 1 as the source of communication between teams.
Prerequisites
To run this tutorial, make sure that the following tools are installed:
- 
Rust The application in this tutorial uses Rust because of its support for WebAssembly (WASM), the language that Smart Rollups use to communicate. Rollups can use any language that has WASM compilation support. To install Rust via the rustupcommand, run this command:curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | shYou can see other ways of installing Rust at https://www.rust-lang.org. 
- 
Clang and LLVM Clang and LLVM are required for compilation to WebAssembly. Version 11 or later of Clang is required. Here are instructions for installing the appropriate tools on different operating systems: MacOS brew install llvm
 export CC="$(brew --prefix llvm)/bin/clang"In some cases for MacOS you may need to update your PATHenvironment variable to include LLVM by running this command:echo 'export PATH="/opt/homebrew/opt/llvm/bin:$PATH"' >> ~/.zshrcUbuntu sudo apt-get install clang-11
 export CC=clang-11Fedora dnf install clang
 export CC=clangArch Linux pacman -S clang
 export CC=clangThe export CCcommand sets Clang as the default C/C++ compiler.After you run these commands, run $CC --versionto verify that you have version 11 or greater installed.Also, ensure that your version of Clang wasm32target with by running the command$CC -print-targets | grep wasm32and verifying that the results includewasm32.
- 
AR (macOS only) To compile to WebAssembly on macOS, you need to use the LLVM archiver. If you used Homebrew to install LLVM, you can configure it to use the archiver by running this command: export AR="$(brew --prefix llvm)/bin/llvm-ar"
- 
WebAssembly Toolkit The WebAssembly Toolkit ( wabt) provides tooling for reducing (or stripping) the size of WebAssembly binaries (with thewasm-stripcommand) and conversion utilities between the textual and binary representations of WebAssembly (including thewat2wasmandwasm2watcommands).Most distributions ship a wabtpackage, which you can install with the appropriate command for your operating system:MacOS brew install wabtUbuntu sudo apt install wabtFedora dnf install wabtArch Linux pacman -S wabtTo verify that wabtis installed, run the commandwasm-strip --versionand verify that the version is at least 1.0.31. If not, you can download this version directly and extract its files: https://github.com/WebAssembly/wabt/releases/tag/1.0.31. Then, whenever you have to usewasm-strip, you can use<path_to_wabt_1.0.31>/bin/wasm-stripinstead.
Tutorial application
Despite the number of command-line tools needed, the code for the core of the rollup itself is relatively simple. This core is called the kernel and is responsible for accepting messages from layer 1 and sending messages to layer 1.
The code for the tutorial application is here: https://gitlab.com/trili/hello-world-kernel.
The code for the kernel is in the src/lib.rs file.
It is written in the Rust programming language and looks like this:
use tezos_smart_rollup::inbox::InboxMessage;
use tezos_smart_rollup::kernel_entry;
use tezos_smart_rollup::michelson::MichelsonBytes;
use tezos_smart_rollup::prelude::*;
kernel_entry!(hello_kernel);
fn handle_message(host: &mut impl Runtime, msg: impl AsRef<[u8]>) {
    if let Some((_, msg)) = InboxMessage::<MichelsonBytes>::parse(msg.as_ref()).ok() {
        debug_msg!(host, "Got message: {:?}\n", msg);
    }
}
pub fn hello_kernel(host: &mut impl Runtime) {
    debug_msg!(host, "Hello, kernel!\n");
    while let Some(msg) = host.read_input().unwrap() {
        handle_message(host, msg);
    }
}
This example kernel has these major parts:
- It imports resources that allow it to access and decode messages from layer 1.
- It runs the Rust macro kernel_entry!to set the main function for the kernel.
- It declares the handle_messagefunction, which accepts, decodes, and processes messages from layer 1. In this case, the function decodes the message (which is sent as a sequence of bytes) and prints it to the log. The function could call any other logic that the application needs to run.
- It declares the hello_kernelfunction, which is the main function for the kernel. It runs each time the kernel receives messages from layer 1, prints a logging message each time it is called, and runs thehandle_messagefunction on each message.
You don't need to access the other files in the application directly, but here are descriptions of them:
- src/lib.rs: The Rust code for the kernel
- Cargo.toml: The dependencies for the build process
- rustup-toolchain.toml: The required Rust version
- sandbox_node.sh: A script that sets up a Tezos sandbox for testing the rollup
The tutorial repository also includes two files that represent example message inboxes in layer 1 blocks:
- empty_input.json: An empty rollup message inbox
- two_inputs.json: A rollup message inbox with two messages
When you're ready, move to the next section to begin setting up the application.