Skip to main content

A natural shell for debugging Juju Kubernetes workload containers via Pebble

Project description

borescope

A natural shell for debugging Juju Kubernetes workload containers.

Kubernetes charm workload containers usually run a rock with no shell — so when something breaks, juju ssh --container=workload … drops you nowhere useful. borescope gives you a prompt that feels like bash but talks to the container's Pebble instead of a real shell:

$ borescope myapp/0
pebble:/# ls /var/log/myapp
pebble:/# tail -f /var/log/myapp/error.log
pebble:/# services
pebble:/# logs --follow myapp
pebble:/# plan
pebble:/# exit

No setup ceremony: borescope picks up your current Juju controller/model and uses your existing juju authority — if you can juju ssh to the unit, borescope works; if you can't, it fails the same way.

Install

v1 is under active development. For now, from a checkout:

uv tool install .        # or: pipx install .

Usage

borescope <unit>                       # default (first) workload container
borescope <unit> --container=<name>    # a specific workload container
borescope --model <model> <unit>
borescope <unit> --command "services"  # one-shot, no REPL (for scripts)
borescope <unit> --snapshot            # dump container state as JSON

Documentation

Full documentation — a tutorial, how-to guides, and CLI/command reference — is at https://tonyandrewmeyer.github.io/borescope/.

The docs are plain Markdown under docs/src/, built into static HTML with a small script (no docs framework). To build them locally:

uv run python docs/src/_build.py     # or: tox -e docs

See docs/README.md for the authoring rules.

How it works

borescope is three thin, independently-testable layers:

  • Transport — talks to a Pebble. The primary backend (CliTransport) reaches the workload's Pebble through the charm containerjuju ssh <unit> (the charm container always has a shell) pointed at the workload's socket, which Juju mounts there at /charm/containers/<name>/pebble.socket. This works even against rocks with no shell (the shell lives in the charm container, not the rock) and stays entirely within your Juju authority — no kubectl or cluster-admin. It drives pebble via shimmer (a drop-in ops.pebble.Client over the Pebble CLI). When the Pebble socket is directly reachable (running inside the charm, or a local Pebble), SocketTransport uses the real ops.pebble.Client HTTP API instead.
  • Discovery — turns a unit reference into the right Pebble: confirms the unit, reads the charm's metadata.yaml for workload container names, and sanity-checks the container is alive. Everything uses your Juju model access — no kubectl / cluster-admin.
  • Shell — a small REPL: cd/pwd, path-aware tab completion, history, and a minimal command set. Pebble's own vocabulary (services, logs, plan, …) is first-class, not hidden behind a pebble prefix. For anything else, exec <cmd> runs a binary that's already in the container.

Scope

borescope is for Kubernetes charms (which run Pebble). Machine charms already have a real shell and are out of scope. It deliberately ships a minimal command set and grows on request — if a tool exists in the container, reach it with exec.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

borescope-0.1.0b2.tar.gz (71.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

borescope-0.1.0b2-py3-none-any.whl (49.1 kB view details)

Uploaded Python 3

File details

Details for the file borescope-0.1.0b2.tar.gz.

File metadata

  • Download URL: borescope-0.1.0b2.tar.gz
  • Upload date:
  • Size: 71.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for borescope-0.1.0b2.tar.gz
Algorithm Hash digest
SHA256 a80adaab6c5a20ed3389fe0821dd45990b48113c19ade3d119995e10863e047c
MD5 ab2d1040efa3619112d59946f03b082c
BLAKE2b-256 82f85e5f29e4e0f03deeb68a37f7089f7c9a84b54d2039cd0ef26780a4991e81

See more details on using hashes here.

Provenance

The following attestation bundles were made for borescope-0.1.0b2.tar.gz:

Publisher: publish.yaml on tonyandrewmeyer/borescope

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file borescope-0.1.0b2-py3-none-any.whl.

File metadata

  • Download URL: borescope-0.1.0b2-py3-none-any.whl
  • Upload date:
  • Size: 49.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for borescope-0.1.0b2-py3-none-any.whl
Algorithm Hash digest
SHA256 7dababa12f3f27a66924e7fa72748922890b70cffcbb41e30540ad9d6f4c4868
MD5 9f5325944139b74d0179dd2dbebd0429
BLAKE2b-256 3b462c7fe03ae1435bda84f0d219c5ec833d38ec955ece9de26c8cd9ca101696

See more details on using hashes here.

Provenance

The following attestation bundles were made for borescope-0.1.0b2-py3-none-any.whl:

Publisher: publish.yaml on tonyandrewmeyer/borescope

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page