docker-wrapper 0.8.3

A Docker CLI wrapper for Rust
Documentation

docker-wrapper

Crates.io Documentation CI License: MIT

A comprehensive, type-safe Docker CLI wrapper for Rust applications.

Features

  • Comprehensive Docker CLI coverage (80+ commands implemented)
  • Type-safe builder pattern API
  • Async/await support with Tokio
  • Real-time output streaming
  • Docker Compose support (optional)
  • Pre-configured container templates (Redis, PostgreSQL, MySQL, MongoDB, Nginx)
  • Docker context management for remote Docker hosts
  • Docker builder commands for build cache management
  • Network and volume management
  • Zero unsafe code
  • Extensive test coverage (750+ tests)

Installation

Add to your Cargo.toml:

[dependencies]
docker-wrapper = "0.5"
tokio = { version = "1", features = ["full"] }

Minimum Supported Rust Version (MSRV): 1.89.0

Enable Docker Compose support:

[dependencies]
docker-wrapper = { version = "0.5", features = ["compose"] }

Quick Start

use docker_wrapper::{DockerCommand, RunCommand};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Run a container
    let output = RunCommand::new("nginx:latest")
        .name("my-web-server")
        .port(8080, 80)
        .detach()
        .execute()
        .await?;

    println!("Container started: {}", output.0);
    Ok(())
}

Important: The DockerCommand trait must be imported to use the .execute() method on any Docker command. This trait provides the core execution functionality for all commands.

Docker Builder Example

use docker_wrapper::{DockerCommand, BuilderPruneCommand};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Clean up build cache
    let result = BuilderPruneCommand::new()
        .all()
        .keep_storage("5GB")
        .force()
        .execute()
        .await?;

    println!("Reclaimed {} bytes of disk space", 
             result.space_reclaimed.unwrap_or(0));
    Ok(())
}

Container Templates

Templates provide pre-configured containers with sensible defaults and best practices:

[dependencies]
docker-wrapper = { version = "0.8", features = ["templates"] }

Quick example:

use docker_wrapper::{RedisTemplate, PostgresTemplate, Template};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Start Redis with persistence and custom image
    let redis = RedisTemplate::new("my-redis")
        .port(6379)
        .password("secret")
        .with_persistence("redis-data")
        .custom_image("redis", "7-alpine")
        .platform("linux/amd64");
    
    let redis_id = redis.start().await?;
    
    // Start PostgreSQL with custom configuration
    let postgres = PostgresTemplate::new("my-postgres")
        .database("myapp")
        .username("appuser") 
        .password("apppass")
        .with_persistence("postgres-data");
    
    let postgres_conn = postgres.start().await?;
    println!("PostgreSQL URL: {}", postgres_conn.connection_url());
    
    Ok(())
}

📖 Complete Template Documentation - Comprehensive guide with examples for all templates

Docker Context Management

use docker_wrapper::{DockerCommand, ContextCreateCommand, ContextUseCommand};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Create a context for remote Docker host
    ContextCreateCommand::new("remote-docker")
        .docker_host("ssh://user@remote-host")
        .description("Remote development server")
        .execute()
        .await?;
    
    // Switch to remote context
    ContextUseCommand::new("remote-docker")
        .execute()
        .await?;
    
    // Now all Docker commands will run on the remote host
    Ok(())
}

Available templates:

  • Redis: RedisTemplate, RedisSentinelTemplate, RedisClusterTemplate, RedisEnterpriseTemplate, RedisInsightTemplate
  • Databases: PostgresTemplate, MysqlTemplate, MongodbTemplate
  • Web Servers: NginxTemplate

All templates support custom images, platforms, persistence, and resource limits. See the Template Documentation for complete usage examples.

When to Use docker-wrapper

docker-wrapper is ideal for:

  • CLI tools and automation scripts - Familiar Docker CLI behavior
  • Docker Compose workflows - Native compose command support
  • Development tools - Container management for dev environments
  • Shell script migration - Type-safe Rust alternative to bash scripts
  • Cross-platform support - Works with Docker, Podman, Colima, etc.

Choosing between Docker Rust libraries? See our comprehensive Comparison Guide comparing docker-wrapper vs bollard vs testcontainers-rs.

Documentation

For comprehensive documentation, examples, and API reference:

Examples

The examples/ directory contains practical examples:

  • basic_usage.rs - Common Docker operations
  • basic_docker_patterns.rs - Essential Docker patterns and best practices
  • exec_examples.rs - Container command execution
  • lifecycle_commands.rs - Container lifecycle management
  • run_examples.rs - Advanced run command usage
  • streaming.rs - Real-time output streaming
  • docker_compose.rs - Docker Compose usage (requires compose feature)
  • debugging_features.rs - Debugging and inspection features
  • system_cleanup.rs - System maintenance and cleanup
  • complete_run_coverage.rs - Comprehensive run command options
  • template_usage.rs - Container templates usage (requires templates feature)
  • network_volume_management.rs - Network and volume management
  • redis_cluster.rs - Redis cluster setup example
  • test_sentinel.rs - Redis Sentinel high availability example
  • redis_enterprise_template.rs - Redis Enterprise cluster with automatic initialization
  • testing_basics.rs - Basic testing patterns with docker-wrapper
  • test_fixtures.rs - Reusable test fixtures for common services

Run examples:

cargo run --example basic_usage
cargo run --example streaming
cargo run --features compose --example docker_compose

Contributing

Contributions are welcome! Please see our Contributing Guide for details.

License

Licensed under the MIT license (LICENSE or http://opensource.org/licenses/MIT).