Rust (Tokio)
This example uses Tokio, a popular Rust asynchronous runtime.
To run this example, follow these steps:
-
Install the
kraftCLI tool and a container runtime engine, for example Docker. -
Clone the
examplesrepository andcdinto theexamples/http-rust1.75-tokio/directory:
Code(bash)
Make sure to log into Unikraft Cloud by setting your token and a metro close to you.
This guide uses fra (Frankfurt, ๐ฉ๐ช):
Code(bash)
When done, invoke the following command to deploy this app on Unikraft Cloud:
Code(bash)
The output shows the instance address and other details:
Code(ansi)
In this case, the instance name is http-rust175-tokio-6gxsp and the address is `https://empty-dawn-3coedrce.fra.unikraft.app.
They're different for each run.
Use curl to query the Unikraft Cloud instance of the Tokio-based HTTP web server:
Code(bash)
Code(text)
You can list information about the instance by running:
Code(bash)
Code(text)
When done, you can remove the instance:
Code(bash)
Customize your app
To customize the app, update the files in the repository, listed below:
src/main.rs: the actual serverCargo.toml: the Cargo package manager configuration fileKraftfile: the Unikraft Cloud specificationDockerfile: the Docker-specified app filesystem
The following options are available for customizing the app:
-
If you only update the implementation in the
src/main.rssource file, you don't need to make any other changes. -
If you create any new source files, copy them into the app filesystem by using the
COPYcommand in theDockerfile. If you add new Rust source code files, be sure to configure required dependencies in theCargo.tomlfile. -
If you build a new executable, update the
cmdline in theKraftfileand replace/serverwith the path to the new executable. -
More extensive changes may require extending the
Dockerfile(seeDockerfilesyntax reference).
Learn more
Use the --help option for detailed information on using Unikraft Cloud:
Code(bash)
Or visit the CLI Reference.