This guide explains how to create and deploy a simple Elixir-based HTTP web server. 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-elixir1.16/directory:
Code
Make sure to log into Unikraft Cloud by setting your token and a metro close to you.
This guide uses fra (Frankfurt, 🇩🇪):
Code
When done, invoke the following command to deploy this app on Unikraft Cloud:
Code
The output shows the instance address and other details:
Code
In this case, the instance name is elixir-qo9k3 and the address is https://small-water-tl8lr8am.fra.unikraft.app.
They're different for each run.
Use curl to query the Unikraft Cloud instance of the Elixir-based HTTP web server:
Code
Code
You can list information about the instance by running:
Code
Code
When done, you can remove the instance:
Code
Customize your app
To customize the app, update the files in the repository, listed below:
lib/,mix.esx: the actual Elixir HTTP serverKraftfile: 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
lib/server.exorlib/server/app.exsource code files, no other changes apply. If you add new source files in thelib/directory, 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. -
More extensive changes may require extending the
Dockerfile(seeDockerfilesyntax reference).
The following commands generate the current source code files and configuration file (mix.exs):
Code
Use a similar command to create a new app. Then update it and deploy it on Unikraft Cloud using the above instructions.
Learn more
Use the --help option for detailed information on using Unikraft Cloud:
Code
Or visit the CLI Reference.