A simple and efficient logging server designed to run inside the host machine to stream logs from the AWS Nitro Enclave.
- GET
logs/stream
-- Creates an SSE connection which can be listened by the client to access realtime logs - GET
/logs/history?log_id=50&offset=10
-- Responds with the logs starting withoffset
number of logs starting from log id =log_id-1
. Omitting log_id param will provide latest produced offset number of logs. - GET
logs/tail-log-id
-- Responds with the id of the last received log - GET
/logs
-- Renders html page to both stream logs realtime and retrieve existing logs.
-
Clone the repository:
git clone https://github.com/your-repo/nitro-enclave-logger.git
-
Navigate to the project directory:
cd nitro-enclave-logger
-
Build the project in release mode:
cargo build --release
Before running the server, you need to grant it permission to bind to server port (default = 516). This is required because ports below 1024 are privileged, and binding to them normally requires root access.
-
Since the program by default uses port 516, run the command below to allow the program to bind to this privileged port:
sudo setcap 'cap_net_bind_service=+ep' ./target/release/logger
-
After setting the capabilities, you can run the server:
./target/release/logger
-
The server will start and listen for http requests on port 516.
- Ensure your firewall and security groups allow traffic on port 516 if you intend to access the server from outside the host machine.
- To reapply the capability (
setcap
) on the binary, run the command again after each rebuild.