Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aedm/esp32-s3-rust-axum-example
Tokio + Axum running on ESP32-S3
https://github.com/aedm/esp32-s3-rust-axum-example
Last synced: 3 months ago
JSON representation
Tokio + Axum running on ESP32-S3
- Host: GitHub
- URL: https://github.com/aedm/esp32-s3-rust-axum-example
- Owner: aedm
- Created: 2024-02-21T08:11:15.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-02-21T12:41:45.000Z (11 months ago)
- Last Synced: 2024-08-02T20:44:21.296Z (6 months ago)
- Language: Rust
- Size: 44.9 KB
- Stars: 11
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-esp-rust - esp32-s3-rust-axum-example - Example of running Tokio + Axum web server on the ESP32-S3. (Projects / `std`)
README
# Rust + Tokio + Axum on ESP32-S3
This is an example application that demonstrates how to use Rust, Tokio and Axum to build a web server on the ESP32-S3 microcontroller.
## Quick Start
You'll need tools:
- `espup` - a tool to install the ESP32 toolchain and other tools
- `cargo-espflash` - a tool to flash the ESP32```
cargo install espup cargo-espflash
espup install
```### Build and run
1. Set the WiFi credentials as environment variables. They will be baked into the executable at build time.
- `WIFI_SSID`
- `WIFI_PASS`
2. This command builds the project and flashes it to the ESP32-S3:
```sh
cargo espflash flash --release --monitor
```### Test it
Once the ESP32-S3 is connected to your network, it displays the IP address on the serial console. The server runs on port 80.
```sh
$ curl http://192.168.0.24/state | jq
{
"counter": 940,
"free_heap": 216452,
"ip_address": "192.168.0.24",
"mac_address": "DC:DA:0C:2A:26:C8",
"message": "Hello from ESP32!"
}
```## But is it any good?
I mean, this is strapping rockets to a bicycle.
It works if you don't overload it. The ESP32-S3 is a microcontroller with limited resources. The web server can only handle a few requests at a time before it runs out of memory.
### Ballpark numbers
- 5 concurrent requests
- 50 requests per secondIf I go over ~5 concurrent requests, IDF runs out of memory and crashes.
Axum wasn't designed for microcontrollers to put it mildly. It's actually a miracle it works at all. I did this for science. We do what we must because we can.
### Alternatives
Besides Axum, Warp also works. It uses somewhat less memory, so you can maybe throw a few more requests at it.
At the time of writing this, Rocket and Actix-web don't work since they require Tokio's `rt-multi-thread` feature which doesn't compile on EPS32 yet.
Honestly, just use MQTT or something. It's a microcontroller, not a server.
## Other ESP32 chips
See `.cargo/config.toml` for the list of supported chips. Set the `target` to the chip you're using.
## Acknowledgements
This project is heavily inspired by Sami J. Mäkinen's [esp32temp](https://github.com/sjm42/esp32temp). Thanks for figuring out how to make this work!
## License
Whatever.