Skip to content

A library for parsing, deploying, and orchestration docker containers and docker-compose systems from YAML and Rust.

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

tangle-network/dockworker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dockworker

A high-performance Rust library for programmatic container orchestration, offering type-safe Docker and Docker Compose operations with advanced deployment capabilities.

Overview

Dockworker bridges the gap between static container configurations and dynamic runtime orchestration. It provides a robust, type-safe interface for programmatically managing containers, with first-class support for both Dockerfile and Docker Compose workflows.

Key Features

đź”’ Type-Safe Container Orchestration

  • Compile-time Validation: Catch configuration errors before deployment with Rust's type system
  • Safe API Abstractions: Memory-safe wrappers around Docker Engine API
  • Error Recovery: Structured error handling with automatic cleanup and rollback capabilities

🚀 Advanced Deployment Capabilities

  • Intelligent Build Context: Automatic dependency tracking and efficient layer caching
  • Variable Substitution: Advanced environment variable interpolation with fallback support
  • Resource Management: Fine-grained control over CPU, memory, and network resources
  • Health Monitoring: Sophisticated health check system with customizable probes

🔄 Docker Compose Integration

  • Declarative & Programmatic: Use YAML configs or build service definitions in code
  • Dependency Resolution: Automatic service ordering based on dependency graphs
  • Network Isolation: Automatic network creation and service discovery
  • Volume Management: Type-safe volume mounting with automatic cleanup

đź›  Developer Experience

  • Async-first Design: Built on tokio for high-performance async I/O
  • Modular Architecture: Use only what you need with feature flags
  • Comprehensive Logging: Detailed operation logging for debugging
  • Testing Utilities: Rich testing infrastructure for container-based tests

Installation

Add to your Cargo.toml:

[dependencies]
# For parsing only (no deployment features)
dockworker = { version = "0.1.0" }

# For full functionality including deployment (default)
dockworker = "0.1.0"

# Or explicitly with all features
dockworker = { version = "0.1.0", features = ["docker"] }

Usage

Feature Flags

  • parser - Enables Dockerfile and Docker Compose parsing functionality (minimal dependencies)
  • deploy - Enables deployment features using Bollard (includes parser features)

Parser-Only Usage

use dockworker::{DockerfileConfig, DockerfileParser, ComposeParser};

// Parse a Dockerfile
let dockerfile_content = std::fs::read_to_string("Dockerfile")?;
let config = DockerfileParser::parse(&dockerfile_content)?;

// Parse a Docker Compose file
let compose_content = std::fs::read_to_string("docker-compose.yml")?;
let compose_config = ComposeParser::parse(&compose_content)?;

Full Deployment Usage

When the deploy feature is enabled:

use dockworker::DockerBuilder;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let builder = DockerBuilder::new()?;
    // ... deployment functionality available
    Ok(())
}

Basic Dockerfile Deployment

use dockworker::{DockerBuilder, DockerfileConfig, DockerCommand};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let builder = DockerBuilder::new()?;

    // Parse existing Dockerfile
    let config = builder.from_dockerfile("path/to/Dockerfile").await?;

    // Or create programmatically
    let config = DockerfileConfig {
        base_image: "rust:1.70".to_string(),
        commands: vec![
            DockerCommand::Run {
                command: "cargo build".to_string()
            },
            DockerCommand::Copy {
                source: "./target".to_string(),
                dest: "/app".to_string(),
                chown: None,
            },
        ],
    };

    // Deploy container
    let container_id = builder.deploy_dockerfile(&config, "my-app:latest").await?;
    Ok(())
}

Docker Compose Deployment

use dockworker::{DockerBuilder, ComposeConfig};
use std::collections::HashMap;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let builder = DockerBuilder::new()?;

    // Parse compose file
    let config = builder.from_compose("docker-compose.yml").await?;

    // Deploy services
    let container_ids: HashMap<String, String> = builder.deploy_compose(&config).await?;
    Ok(())
}

Resource Management

use dockworker::{Service, ResourceLimits};

let service = Service {
    image: Some("nginx:latest".to_string()),
    requirements: Some(ResourceLimits {
        cpu_limit: Some(0.5),                        // Half a CPU
        memory_limit: Some("512M".to_string()),      // 512MB memory limit
        memory_swap: Some("1G".to_string()),         // 1GB swap limit
        memory_reservation: Some("256M".to_string()), // 256MB soft limit
        cpus_shares: Some(512),                      // CPU shares (relative weight)
        cpuset_cpus: Some("0,1".to_string()),        // Run on CPUs 0 and 1
    }),
    ..Default::default()
};

Health Checks

use dockworker::{Service, config::compose::HealthCheck};

let service = Service {
    image: Some("nginx:latest".to_string()),
    healthcheck: Some(HealthCheck {
        test: vec![
            "CMD-SHELL".to_string(),
            "curl -f http://localhost/ || exit 1".to_string()
        ],
        interval: Some(1_000_000_000),    // 1 second
        timeout: Some(3_000_000_000),     // 3 seconds
        retries: Some(3),
        start_period: Some(2_000_000_000), // 2 seconds
        start_interval: None,
    }),
    ..Default::default()
};

Container Management

use dockworker::DockerBuilder;
use std::collections::HashMap;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let builder = DockerBuilder::new()?;

    // Get container logs
    let logs = builder.get_container_logs("container_id").await?;

    // Execute command in container
    let output = builder.exec_in_container(
        "container_id",
        vec!["ls", "-la"],
        Some(HashMap::new()),
    ).await?;

    // Create and manage volumes
    builder.create_volume("my_volume").await?;
    let volumes = builder.list_volumes().await?;

    Ok(())
}

Error Handling

The library provides detailed error types for proper error handling:

use dockworker::DockerError;

match result {
    Err(DockerError::FileError(e)) => println!("File error: {}", e),
    Err(DockerError::YamlError(e)) => println!("YAML parsing error: {}", e),
    Err(DockerError::DockerfileError(e)) => println!("Dockerfile parsing error: {}", e),
    Err(DockerError::BollardError(e)) => println!("Docker API error: {}", e),
    Err(DockerError::InvalidIpamConfig) => println!("Invalid network configuration"),
    Err(DockerError::ContainerNotRunning(id)) => println!("Container {} not running", id),
    Err(DockerError::NetworkCreationError(e)) => println!("Network creation failed: {}", e),
    Err(DockerError::InvalidResourceLimit(e)) => println!("Invalid resource limit: {}", e),
    Ok(_) => println!("Operation succeeded"),
}

Development Status

This library is in active development. Current focus areas:

  • Enhanced error handling with recovery strategies
  • Comprehensive integration testing
  • Additional Docker Compose features
  • Improved resource management
  • Better developer ergonomics

License

This project is licensed under either of

at your discretion.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request. When contributing:

  1. Fork the repository
  2. Create a feature branch
  3. Add tests for new functionality
  4. Ensure all tests pass
  5. Submit a pull request

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Acknowledgments

  • Bollard - The underlying Docker API client
  • Docker - Container platform

About

A library for parsing, deploying, and orchestration docker containers and docker-compose systems from YAML and Rust.

Topics

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages