Please install the prerequisites first!
$ docker run -dp 8080:8080 --rm --runtime=io.containerd.wasmedge.v1 --platform=wasi/wasm secondstate/rust-example-server:latest
... ...
$ curl http://localhost:8080/
Try POSTing data to /echo such as: `curl localhost:8080/echo -XPOST -d 'hello world'`
$ curl http://localhost:8080/echo -X POST -d "Hello WasmEdge"
Hello WasmEdge
The src/main.rs
source code shows how to start an async server using the hyper
crate.
- The
main()
function is now anasync
function and annotated with thetokio
macro. That means the tokio controller can spawn multiple instances of themain()
app. - Each instance of the
main()
app listens at port 8080 without blocking the port for everyone else. It receives a datastream
for each incoming HTTP connection it captures.- The
accept()
function runs in a loop. It accepts an incoming connection, processes its data, and then start over. - Since the data connection could be slow, the
accept()
function could take a long time to return. But it is async, meaning that multiple instances ofaccept()
could run concurrently to receive data from multiple connections on the same port. - The
await
blocks each instance ofaccept()
so that the statements afteraccept()
would not run untilaccept()
receives all the data in a connection and returns.
- The
- The
tokio::task::spawn
API designate thehandle_request()
function to be called whenever the datastream
is available. - The data in the
stream
, which is a HTTP request is passed tohandle_request()
, and the function returns an HTTP response struct. - Inside
handle_request()
, it matches both the HTTP request method and path.- If the HTTP request is a GET at
/
, it returns a response with a help message. - If the HTTP request is a POST at
/echo
, it extracts the HTTP body and echoes it back as the HTTP response. - If no match is found, it returns an HTTP 404 error code.
- If the HTTP request is a GET at
Compile the Rust source code project to a Wasm bytecode file.
$ cargo build --target wasm32-wasi --release
Run the Wasm bytecode file in WasmEdge CLI.
$ wasmedge target/wasm32-wasi/release/server.wasm
Listening on http://0.0.0.0:8080
From another terminal window, do the following.
$ curl http://localhost:8080/
Try POSTing data to /echo such as: `curl localhost:8080/echo -XPOST -d 'hello world'`
$ curl http://localhost:8080/echo -X POST -d "Hello WasmEdge"
Hello WasmEdge
The Dockerfile
follows the above steps to build and package a lightweight OCI-compliant container image for the Wasm app.
Now, we need to publish the container image to Docker Hub. The process is slightly different depending on how you plan to use the image.
For containerd based systems, such as the Docker Desktop and many flavors of Kubernetes,
you just need to specify that the WasmEdge application image is for the wasi/wasm
platform.
$ docker buildx build --provenance=false --platform wasi/wasm -t secondstate/rust-example-server .
... ...
$ docker push secondstate/rust-example-server