Containerized NBS (NIST Beamline Software) services for beamline simulation
Project description
NBS Pods
Containerized NBS (NIST Beamline Software) services for beamline simulation.
Container Images
This repository provides containerized NBS services that can be run in two modes:
Demo Mode (Pre-built Images)
Uses pre-built images from GitHub Container Registry (GHCR):
# Images are automatically built and pushed to:
# ghcr.io/xraygui/nbs-pods/bluesky:latest
# ghcr.io/xraygui/nbs-pods/nbs:latest
# ghcr.io/xraygui/nbs-pods/nbs-gui:latest
Development Mode (Local Builds)
Build images locally for development:
# Build all images
podman-compose -f docker-compose.build.yml build
# Build specific image
podman-compose -f docker-compose.build.yml build nbs
# Rebuild with no caching
podman-compose -f docker-compose.build.yml build --no-cache nbs_gui
Image Dependencies
fedora → bluesky → nbs → nbs-gui
Usage
Demo Mode (Default)
# Start all services with pre-built images
./scripts/deploy.sh start
# Start specific services
./scripts/deploy.sh start gui queueserver
# Start demo services (bluesky-services, gui, queueserver, sim, viewer)
./scripts/deploy.sh demo
Development Mode
# Build images locally first
podman-compose -f docker-compose.build.yml build
# Start specific services in development mode
./scripts/deploy.sh start --dev gui
# Mix normal and development mode
./scripts/deploy.sh start queueserver --dev gui
Stopping Services
# Stop all services
./scripts/deploy.sh stop
# Stop specific services
./scripts/deploy.sh stop gui queueserver
Available Services
- bluesky-services: Core infrastructure (Redis, MongoDB, Kafka, ZMQ proxies)
- queueserver: RE Manager for experiment orchestration
- gui: NBS GUI with display protocol detection (Wayland/X11)
- sim: NBS simulation services
- viewer: Additional viewing services (if configured)
Development Workflow
Docker Compose Override System
The deployment system uses Docker Compose's override mechanism to enable flexible configuration:
- Base Configuration: Each service has a main
docker-compose.ymlfile with default settings - Override Files:
docker-compose.override.ymlfiles (if present) are automatically composed with the main file - Development Files:
docker-compose.development.ymlfiles are applied when using the--devflag
Override Files (docker-compose.override.yml)
Override files allow local customization without modifying the base configuration:
- Testing: Override environment variables, ports, or volumes for testing
- Bug Fixes: Temporarily modify service parameters to work around issues
- GUI Configuration: Especially useful for display protocol issues (Wayland/X11)
- Local Paths: Mount local directories for configuration or data
Example override file:
services:
qs-gui:
volumes:
- ${HOME}/local-config:/etc/bluesky
environment:
- DEBUG=true
Development Files (docker-compose.development.yml)
Development files are applied when using the --dev flag and typically:
- Switch to Local Images: Use locally built images instead of GHCR images
- Config Mounts: Mount configuration directories to test config changes
- Code Mounts: Mount local source code directories for live development
- Local Installs: Install packages from local paths with
pip install -e - Debug Settings: Enable debugging, logging, or development-specific configurations
Example development file which only mounts local config directories
services:
qs-gui:
volumes:
- ${NBS_PODS_DIR}/config/bluesky:/etc/bluesky
- ${BEAMLINE_PODS_DIR}/config/ipython:/usr/local/share/ipython
- ${NBS_PODS_DIR}/config/tiled:/etc/tiled
Example development file which installs local code
services:
nbs-sim:
volumes:
- ${NBSDIR}:/usr/local/src/xraygui
- ${BEAMLINE_PODS_DIR}/config/ipython:/usr/local/share/ipython
command: >
bash -c "
pip3 install --no-deps --no-build-isolation -e /usr/local/src/xraygui/nbs-sim/src &&
nbs-sim --startup-dir /usr/local/share/ipython/profile_default/startup --list-pvs
"
File Resolution Order
The system resolves compose files in this order:
- Base service file (e.g.,
docker-compose.yml) - Override file (
docker-compose.override.yml) - if present - Development file (
docker-compose.development.yml) - if--devflag used
Later files override earlier ones, allowing for flexible configuration management.
Configuration
Images include default configurations in /etc/bluesky and /etc/tiled/profiles which can be overridden with volume mounts in development mode.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nbs_pods-0.2.5.tar.gz.
File metadata
- Download URL: nbs_pods-0.2.5.tar.gz
- Upload date:
- Size: 196.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
075f39a227bba75160f281f4372fd8acd5ab0e3208a410f2fa22a5afe758fd56
|
|
| MD5 |
534fe45af5686c752193440a97acaea5
|
|
| BLAKE2b-256 |
416fd99681ceb86c40c6453caa66001125bcf09c3bef1f2889908a056b1a7233
|
Provenance
The following attestation bundles were made for nbs_pods-0.2.5.tar.gz:
Publisher:
python-publish.yml on xraygui/nbs-pods
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nbs_pods-0.2.5.tar.gz -
Subject digest:
075f39a227bba75160f281f4372fd8acd5ab0e3208a410f2fa22a5afe758fd56 - Sigstore transparency entry: 1421186722
- Sigstore integration time:
-
Permalink:
xraygui/nbs-pods@73794ea6b2682b36270151dd8b23abaa8e275a0d -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/xraygui
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@73794ea6b2682b36270151dd8b23abaa8e275a0d -
Trigger Event:
release
-
Statement type:
File details
Details for the file nbs_pods-0.2.5-py3-none-any.whl.
File metadata
- Download URL: nbs_pods-0.2.5-py3-none-any.whl
- Upload date:
- Size: 197.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c7fdab9868ab0df14dbb10697b5fcc65de9bb28daa82c3480eab19e4e3c6365
|
|
| MD5 |
e98a157890d66632193b166cdff261af
|
|
| BLAKE2b-256 |
905272a2658f67f629871fe71f41097065b1c7b92192ecf46193b87729258f6f
|
Provenance
The following attestation bundles were made for nbs_pods-0.2.5-py3-none-any.whl:
Publisher:
python-publish.yml on xraygui/nbs-pods
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nbs_pods-0.2.5-py3-none-any.whl -
Subject digest:
4c7fdab9868ab0df14dbb10697b5fcc65de9bb28daa82c3480eab19e4e3c6365 - Sigstore transparency entry: 1421186808
- Sigstore integration time:
-
Permalink:
xraygui/nbs-pods@73794ea6b2682b36270151dd8b23abaa8e275a0d -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/xraygui
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@73794ea6b2682b36270151dd8b23abaa8e275a0d -
Trigger Event:
release
-
Statement type: