🎉 Init
This commit is contained in:
commit
d4b014fbcd
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
/target
|
||||
/.env
|
||||
8
.idea/.gitignore
generated
vendored
Normal file
8
.idea/.gitignore
generated
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
# Default ignored files
|
||||
/shelf/
|
||||
/workspace.xml
|
||||
# Editor-based HTTP Client requests
|
||||
/httpRequests/
|
||||
# Datasource local storage ignored files
|
||||
/dataSources/
|
||||
/dataSources.local.xml
|
||||
8
.idea/modules.xml
generated
Normal file
8
.idea/modules.xml
generated
Normal file
@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/node-monitoring.iml" filepath="$PROJECT_DIR$/.idea/node-monitoring.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
11
.idea/node-monitoring.iml
generated
Normal file
11
.idea/node-monitoring.iml
generated
Normal file
@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="EMPTY_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/target" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
||||
1606
Cargo.lock
generated
Normal file
1606
Cargo.lock
generated
Normal file
File diff suppressed because it is too large
Load Diff
8
Cargo.toml
Normal file
8
Cargo.toml
Normal file
@ -0,0 +1,8 @@
|
||||
[package]
|
||||
name = "node-monitoring"
|
||||
version = "0.1.0"
|
||||
edition = "2024"
|
||||
|
||||
[dependencies]
|
||||
rocket = "0.5.1"
|
||||
libc = "0.2"
|
||||
19
Dockerfile
Normal file
19
Dockerfile
Normal file
@ -0,0 +1,19 @@
|
||||
# Stage 1: Build
|
||||
FROM rust:1.91.1-slim AS builder
|
||||
|
||||
# Create app directory
|
||||
WORKDIR /usr/src/app
|
||||
|
||||
# Copy source code
|
||||
COPY . .
|
||||
|
||||
# Build the actual app
|
||||
RUN cargo build --release
|
||||
|
||||
# Stage 2: Runtime
|
||||
FROM debian:stable-slim
|
||||
|
||||
# Copy the compiled binary from the builder stage
|
||||
COPY --from=builder /usr/src/app/target/release/node-monitoring /usr/local/bin/node-monitoring
|
||||
|
||||
CMD ["/usr/local/bin/node-monitoring"]
|
||||
35
src/main.rs
Normal file
35
src/main.rs
Normal file
@ -0,0 +1,35 @@
|
||||
use std::{env, ffi::CString};
|
||||
use libc::{statvfs};
|
||||
use rocket::http::Status;
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/")]
|
||||
fn index() -> Result<String, Status> {
|
||||
let host_path = env::var("HOST_PATH").unwrap_or_else(|_| "/".to_string());
|
||||
let path = CString::new(host_path.clone()).map_err(|_| Status::InternalServerError)?;
|
||||
let mut stat: statvfs = unsafe { std::mem::zeroed() };
|
||||
|
||||
let result = unsafe { statvfs(path.as_ptr(), &mut stat) };
|
||||
if result == 0 {
|
||||
let block_size = stat.f_frsize as u64;
|
||||
let total = stat.f_blocks as u64 * block_size;
|
||||
let free = stat.f_bfree as u64 * block_size;
|
||||
let used = total - free;
|
||||
let percentage_used = ((used as f64 / total as f64) * 100.0) as u64;
|
||||
|
||||
return Ok(format!("path:{}\ntotal-space:{}\nused-space:{}\npercentage_used:{}", host_path,total, used, percentage_used))
|
||||
}
|
||||
Err(Status::InternalServerError)
|
||||
}
|
||||
|
||||
#[launch]
|
||||
fn rocket() -> _ {
|
||||
|
||||
println!("____ __ __ __ ___ _ __ _ ");
|
||||
println!("__/ |/ /__ ___/ /__ / |/ /__ ___ (_) /____ ____(_)__ ___ _");
|
||||
println!("_/ / _ \\/ _ / -_) /|_/ / _ \\/ _ \\/ / __/ _ \\/ __/ / _ \\/ _ `/");
|
||||
println!("/_/|_/\\___/\\_,_/\\__/_/ /_/\\___/_//_/_/\\__/\\___/_/ /_/_//_/\\_, / ");
|
||||
println!(" /___/ ");
|
||||
rocket::custom(rocket::Config { address: "0.0.0.0".parse().unwrap(), port: 8080, ..Default::default() }).mount("/", routes![index])
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user