Metadata-Version: 2.4
Name: minitrino
Version: 3.0.3
Summary: A command line tool that makes it easy to run modular Trino environments locally.
Author-email: Jeff Lester <jeff.lester.dev@gmail.com>
License: Apache-2.0
Project-URL: Homepage, https://github.com/jefflester/minitrino
Keywords: docker,minitrino,starburst,trino
Requires-Python: >=3.10.12
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: PyYAML>=6.0.1
Requires-Dist: click==8.3.1
Requires-Dist: docker==7.1.0
Requires-Dist: humanize
Requires-Dist: jsonschema>=4.18.0
Requires-Dist: python-dateutil
Requires-Dist: requests>=2.32.2
Requires-Dist: tabulate
Provides-Extra: dev
Requires-Dist: bandit; extra == "dev"
Requires-Dist: deptry; extra == "dev"
Requires-Dist: docformatter; extra == "dev"
Requires-Dist: mdformat; extra == "dev"
Requires-Dist: mdformat-gfm; extra == "dev"
Requires-Dist: mdformat-myst; extra == "dev"
Requires-Dist: mypy; extra == "dev"
Requires-Dist: pre-commit; extra == "dev"
Requires-Dist: pydocstyle; extra == "dev"
Requires-Dist: ruff; extra == "dev"
Requires-Dist: setuptools; extra == "dev"
Requires-Dist: tomli; extra == "dev"
Requires-Dist: types-click; extra == "dev"
Requires-Dist: types-docker; extra == "dev"
Requires-Dist: types-jsonschema; extra == "dev"
Requires-Dist: types-PyYAML; extra == "dev"
Requires-Dist: types-python-dateutil; extra == "dev"
Requires-Dist: types-setuptools; extra == "dev"
Requires-Dist: types-tabulate; extra == "dev"
Requires-Dist: vulture; extra == "dev"
Requires-Dist: wheel; extra == "dev"
Requires-Dist: yamllint; extra == "dev"
Provides-Extra: docs
Requires-Dist: ablog; extra == "docs"
Requires-Dist: myst_parser; extra == "docs"
Requires-Dist: numpydoc; extra == "docs"
Requires-Dist: pydata-sphinx-theme; extra == "docs"
Requires-Dist: sphinx; extra == "docs"
Requires-Dist: sphinx-click; extra == "docs"
Requires-Dist: sphinx-copybutton; extra == "docs"
Requires-Dist: sphinx-design; extra == "docs"
Requires-Dist: sphinx-favicon; extra == "docs"
Requires-Dist: sphinx-togglebutton; extra == "docs"
Requires-Dist: sphinxext-opengraph; extra == "docs"
Dynamic: license-file

<p align="center">
    <img alt="Minitrino Logo" src=".github/img/minitrino-small.png" />
</p>

# Minitrino

A command line tool that makes it easy to run modular Trino environments locally.

[![PyPI
version](https://img.shields.io/pypi/v/minitrino)](https://pypi.org/project/minitrino/)
![CI
Tests](https://github.com/jefflester/minitrino/actions/workflows/ci.yaml/badge.svg)
[![Trino
Slack](https://img.shields.io/static/v1?logo=slack&logoColor=959DA5&label=Slack&labelColor=333a41&message=join%20conversation&color=3AC358)](https://trinodb.io/slack.html)

______________________________________________________________________

> **📘 [Complete Documentation](https://minitrino.readthedocs.io/)** - User
> guides, API reference, and all 39 modules

______________________________________________________________________

**Latest Stable Release**: 3.0.3

## What is Minitrino?

Minitrino lets you spin up complete Trino or Starburst clusters locally with
minimal configuration. Mix and match from **39+ modules** to create the exact
environment you need:

- **Catalogs**: Hive, Iceberg, Delta Lake, Postgres, MySQL, ClickHouse,
  Elasticsearch, and more
- **Security**: LDAP, OAuth2, Kerberos, TLS, BIAC, password files
- **Admin Tools**: MinIO, Insights, Cache Service, Resource Groups, SCIM

Perfect for local development, testing configurations, learning features, and
plugin development.

## Compatibility

- **[Trino](https://trino.io/)** versions 443 and later
- **[Starburst Enterprise](https://docs.starburst.io/latest/index.html)**
  versions 443-e and later

## Quick Start

### Installation

```sh
pip install minitrino
minitrino lib-install
```

### Run Your First Cluster

```sh
# Start a Trino cluster with Hive and Iceberg
minitrino -v provision -m hive -m iceberg

# Access the Trino UI at http://localhost:8080
# Or connect with the CLI
minitrino exec -i 'trino-cli'
```

### Switch to Starburst

```sh
# Use Starburst with enterprise modules
minitrino -v provision -i starburst -m insights -m cache-service
```

### Clean Up

```sh
minitrino down    # Stop the cluster
minitrino remove  # Remove all resources
```

## Key Features

- 🎯 **Zero Config** - Start clusters with a single command
- 🔧 **39+ Modules** - Pre-configured catalogs, security, and admin tools
- 🐳 **Docker-Based** - Isolated containers, no system pollution
- 🔄 **Multi-Cluster** - Run multiple independent clusters simultaneously
- 🚀 **Fast Setup** - First provision ~5 min, subsequent provisions ~30 sec
- 📦 **Both Distributions** - Switch between Trino and Starburst with a flag

## Documentation

**📘 [Complete Documentation](https://minitrino.readthedocs.io/)**

### Getting Started

- [Installation &
  Upgrades](https://minitrino.readthedocs.io/en/latest/get-started/user/installation-and-upgrades.html)
  - Install via PyPI, upgrade procedures, version compatibility
- [Workflow
  Examples](https://minitrino.readthedocs.io/en/latest/get-started/user/workflow-examples.html)
  - Complete guide with provisioning, modules, and configuration
- [CLI
  Reference](https://minitrino.readthedocs.io/en/latest/get-started/user/cli-reference.html)
  - All commands, options, and flags
- [Troubleshooting](https://minitrino.readthedocs.io/en/latest/get-started/user/troubleshooting.html)
  - Common issues and solutions

### For Developers

- [Build a
  Module](https://minitrino.readthedocs.io/en/latest/get-started/dev/build-a-module.html)
  - Step-by-step module creation guide
- [Testing
  Guide](https://minitrino.readthedocs.io/en/latest/get-started/dev/cli-and-library-tests.html)
  - CLI and library test documentation
- [GitHub
  Workflows](https://minitrino.readthedocs.io/en/latest/get-started/dev/github-workflows.html)
  - CI/CD and release process

### Resources

- [All
  Modules](https://minitrino.readthedocs.io/en/latest/modules/index.html) -
  Browse all 39 admin, catalog, and security modules
- [Environment Variables &
  Config](https://minitrino.readthedocs.io/en/latest/get-started/user/environment-variables-and-config.html)
  - Configuration hierarchy and customization
- [API
  Reference](https://minitrino.readthedocs.io/en/latest/api/index.html) -
  Python API documentation

## Support & Community

- 📖 [Documentation](https://minitrino.readthedocs.io/)
- 🐛 [Report
  Issues](https://github.com/jefflester/minitrino/issues)
- 💬 [Trino Slack](https://trinodb.io/slack.html)
- 🤝 [Contributing
  Guide](https://minitrino.readthedocs.io/en/latest/get-started/user/reporting-bugs-and-contributing.html)
