Skip to content

An engine which extracts metadata from messages, and writes them to different storages. Optimized for fast I/O and Network throughput.

Notifications You must be signed in to change notification settings

shivanshuraj1333/storage-engine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenTelemetry Storage Engine

A high-performance asynchronous trace storage engine built with Rust, featuring OpenTelemetry protocol support, S3-compatible storage, and health monitoring.

Features

  • OpenTelemetry Support

    • OTLP protocol implementation
    • Trace collection and storage
    • Span batching and processing
  • Storage

    • S3-compatible backend
    • Configurable batching
    • Efficient data organization
  • Monitoring

    • Health check endpoints
    • Performance metrics
    • Error tracking
  • API

    • gRPC for trace collection
    • REST for querying spans
    • Health status endpoints

Quick Start

  1. Prerequisites
# Required tools
- Rust 1.70+
- Docker
- AWS CLI
  1. Setup LocalStack
# Start LocalStack
docker run --rm -it -p 4566:4566 localstack/localstack

# Create test bucket
aws --endpoint-url=http://localhost:4566 s3 mb s3://my-test-bucket
  1. Run the Server
# Build and run with logging
RUST_LOG=info cargo run
  1. Test with Example Client
# Run the test client
RUST_LOG=info cargo run --example grpc_client --features client

Architecture

graph TD

    %% ---------------------------------------------
    %%  GLOBAL STYLES
    %% ---------------------------------------------
    classDef default font-size:14px

    %% ---------------------------------------------
    %%  CLIENT LAYER
    %% ---------------------------------------------
    subgraph Clients["External Clients"]
        OTLP[OpenTelemetry Client]
        HTTP[HTTP Client]
        style OTLP fill:#E9ECEF,stroke:#495057,color:#000
        style HTTP fill:#E9ECEF,stroke:#495057,color:#000
    end

    %% ---------------------------------------------
    %%  SERVER LAYER
    %% ---------------------------------------------
    subgraph Server["Server Layer (src/server.rs)"]
        GS[gRPC Server]
        HS[HTTP Server]
        LS[ListenerServer]
        Router[Axum Router]
        style GS fill:#DBE4FF,stroke:#364FC7,color:#000
        style HS fill:#DBE4FF,stroke:#364FC7,color:#000
        style LS fill:#DBE4FF,stroke:#364FC7,color:#000
        style Router fill:#DBE4FF,stroke:#364FC7,color:#000
    end

    %% ---------------------------------------------
    %%  PROCESSING LAYER
    %% ---------------------------------------------
    subgraph Core["Processing Layer (src/core.rs)"]
        EC[EngineCore]
        Queue[Message Queue]
        Batch[Batch Processor]
        ME[Metadata Extractor]:::planned
        Conv[Span Converter]
        style EC fill:#D3F9D8,stroke:#2B8A3E,color:#000
        style Queue fill:#D3F9D8,stroke:#2B8A3E,color:#000
        style Batch fill:#D3F9D8,stroke:#2B8A3E,color:#000
        style Conv fill:#D3F9D8,stroke:#2B8A3E,color:#000
    end

    %% ---------------------------------------------
    %%  HEALTH MONITORING
    %% ---------------------------------------------
    subgraph Health["Health Monitoring (src/health.rs)"]
        HM[Health Monitor]
        Metrics[Health Metrics]
        Status[Health Status]
        style HM fill:#FFF3BF,stroke:#94710C,color:#000
        style Metrics fill:#FFF3BF,stroke:#94710C,color:#000
        style Status fill:#FFF3BF,stroke:#94710C,color:#000
    end

    %% ---------------------------------------------
    %%  STORAGE LAYER
    %% ---------------------------------------------
    subgraph Storage["Storage Layer (src/storage/mod.rs)"]
        SW[StorageWriter Trait]
        S3W[S3StorageWriter]
        Reader[SpanReader]
        style SW fill:#D0BFFF,stroke:#5F3DC4,color:#000
        style S3W fill:#D0BFFF,stroke:#5F3DC4,color:#000
        style Reader fill:#D0BFFF,stroke:#5F3DC4,color:#000
    end

    %% ---------------------------------------------
    %%  INFRASTRUCTURE (CONFIG + ERRORS)
    %% ---------------------------------------------
    subgraph Infrastructure["Infrastructure"]
        direction TB
        Config[Configuration]
        Errors[Error Handling]
        style Config fill:#FFD8A8,stroke:#D9480F,color:#000
        style Errors fill:#FFD8A8,stroke:#D9480F,color:#000
    end

    %% ---------------------------------------------
    %%  DATA FLOW - MAIN PATH
    %% ---------------------------------------------
    OTLP -->|"OTLP Protocol"| GS
    HTTP -->|"REST Endpoint"| HS
    GS --> LS
    HS --> Router
    LS -->|"Channel"| Queue
    Queue --> EC
    EC --> Batch
    Batch --> ME
    ME --> Conv
    Conv --> SW
    SW --> S3W
    S3W -->|"Persist"| S3[(S3 Storage)]
    Reader -->|"Query"| S3W
    Router --> Reader

    %% ---------------------------------------------
    %%  MONITORING & CONFIG FLOW
    %% ---------------------------------------------
    EC -.->|"Report"| HM
    S3W -.->|"Report"| HM
    HM -->|"Update"| Metrics
    Config -.->|"Configure"| EC
    Config -.->|"Configure"| S3W

    %% ---------------------------------------------
    %%  ERROR FLOW
    %% ---------------------------------------------
    EC -.->|"Error"| Errors
    S3W -.->|"Error"| Errors

    %% ---------------------------------------------
    %%  STYLING FOR PLANNED COMPONENTS
    %% ---------------------------------------------
    classDef planned fill:#F1F3F5,stroke:#868E96,stroke-dasharray:5,5,color:#000

    %% ---------------------------------------------
    %%  LEGEND
    %% ---------------------------------------------
    subgraph Legend
        direction LR
        Implemented[Implemented]
        Planned[Planned]:::planned
        style Implemented fill:#E9ECEF,stroke:#495057,color:#000
    end

    %% ---------------------------------------------
    %%  SUBGRAPH STYLES
    %% ---------------------------------------------
    %% Make subgraph backgrounds match their nodes & show subgraph titles in black
    style Clients fill:#E9ECEF,stroke:#495057,color:#000
    style Server fill:#DBE4FF,stroke:#364FC7,color:#000
    style Core fill:#D3F9D8,stroke:#2B8A3E,color:#000
    style Health fill:#FFF3BF,stroke:#94710C,color:#000
    style Storage fill:#D0BFFF,stroke:#5F3DC4,color:#000
    style Infrastructure fill:#FFD8A8,stroke:#D9480F,color:#000
    style Legend fill:#E9ECEF,stroke:#495057,color:#000
Loading

Component Details

  1. Server Layer (Implemented)

    • Handles incoming OTLP and HTTP requests
    • Routes requests to appropriate handlers
    • Manages connection lifecycle
  2. Processing Layer

    • EngineCore: Central processing unit (Implemented)
    • Message Queue: Async message handling (Implemented)
    • Metadata Extractor: Span metadata analysis (Planned)
    • Batch Processor: Efficient batch operations (Implemented)
  3. Storage Layer (Implemented)

    • Abstract storage interface
    • S3-compatible implementation
    • Span querying capabilities
    • Data organization
  4. Health Monitoring (Implemented)

    • System health tracking
    • Performance metrics
    • Resource utilization
    • Error rate monitoring
  5. Infrastructure

    • Configuration management (Implemented)
    • Error handling (Implemented)
    • Logging and metrics (Implemented)

Planned Features

  1. Metadata Extractor
    • Service dependency mapping
    • Performance pattern detection
    • Anomaly identification
    • Relationship analysis

API Reference

gRPC Endpoints

  • /opentelemetry.proto.collector.trace.v1.TraceService/Export
    • Accepts OTLP trace data
    • Batches and stores spans

HTTP Endpoints

  • GET /spans
    • Query recent spans
    • Optional limit parameter
  • GET /health
    • System health status
    • Performance metrics

Configuration

Configuration can be provided via:

  1. Environment variables
  2. YAML configuration file
  3. Default values

Environment Variables

SERVER_HOST=0.0.0.0
SERVER_PORT=50051
STORAGE_BUCKET=my-test-bucket
RUST_LOG=info

YAML Configuration

server:
  host: "0.0.0.0"
  port: 50051
storage:
  bucket: "my-test-bucket"
  prefix: "traces"
processing:
  batch_size: 100
  batch_timeout_ms: 5000

Development

Build Commands

make setup-proto  # Setup OpenTelemetry protos
make build       # Build the project
make test        # Run tests
make lint        # Run lints
make run         # Run server
make run-client  # Run test client

Project Structure

.
├── proto/              # Protocol definitions
├── src/
│   ├── config/        # Configuration
│   ├── core/          # Processing engine
│   ├── health/        # Health monitoring
│   ├── proto/         # Generated code
│   ├── server/        # gRPC server
│   └── storage/       # Storage backend
└── examples/          # Usage examples

Testing

# Unit tests
cargo test

# Integration tests
cargo test --test '*'

# With logging
RUST_LOG=debug cargo test

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Run tests and lints
  5. Submit a pull request

License

MIT License

About

An engine which extracts metadata from messages, and writes them to different storages. Optimized for fast I/O and Network throughput.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published