omni_containers

Docker container management

Overview

PackageVersionCategoryLicenseLanguage
omnigres0.2.0FEATApache-2.0C
IDExtensionBinLibLoadCreateTrustRelocSchema
2940omniNoYesYesYesNoNoomni
2941omni_authNoNoNoYesNoNoomni_auth
2942omni_awsNoNoNoYesYesNoomni_aws
2943omni_cloudeventsNoNoNoYesYesNoomni_cloudevents
2944omni_containersNoYesNoYesNoNoomni_containers
2945omni_credentialsNoNoNoYesNoNoomni_credentials
2948omni_emailNoNoNoYesNoNoomni_email
2949omni_httpNoNoNoYesNoNoomni_http
2950omni_httpcNoYesNoYesNoNoomni_httpc
2951omni_httpdNoYesNoYesNoNoomni_httpd
2952omni_idNoYesNoYesNoYes-
2953omni_jsonNoNoNoYesYesNoomni_json
2954omni_kubeNoYesNoYesNoNoomni_kube
2955omni_ledgerNoYesNoYesNoNoomni_ledger
2956omni_manifestNoNoNoYesNoNoomni_manifest
2957omni_mimetypesNoNoNoYesNoNoomni_mimetypes
2958omni_osNoYesNoYesNoNoomni_os
2959omni_polyfillNoYesNoYesNoNoomni_polyfill
2960omni_pythonNoYesNoYesNoNoomni_python
2961omni_regexNoYesNoYesNoYes-
2962omni_restNoNoNoYesNoNoomni_rest
2963omni_schemaNoNoNoYesNoNoomni_schema
2964omni_seqNoYesNoYesNoNoomni_seq
2965omni_serviceNoNoNoYesNoNoomni_service
2966omni_sessionNoNoNoYesNoNoomni_session
2968omni_sqlNoYesNoYesNoNoomni_sql
2969omni_sqliteNoYesNoYesNoNoomni_sqlite
2970omni_testNoNoNoYesNoNoomni_test
2971omni_txnNoYesNoYesNoNoomni_txn
2972omni_typesNoYesNoYesNoNoomni_types
2973omni_varNoYesNoYesNoNoomni_var
2974omni_vfsNoYesNoYesNoNoomni_vfs
2975omni_vfs_types_v1NoNoNoYesNoNoomni_vfs_types_v1
2976omni_webNoYesNoYesNoNoomni_web
2977omni_workerNoYesNoYesNoNoomni_worker
2978omni_xmlNoYesNoYesNoNoomni_xml
2979omni_yamlNoYesNoYesNoNoomni_yaml
Relatedomni_httpc omni_web

Version

TypeRepoVersionPG VerPackageDeps
EXTPIGSTY0.2.01817161514omnigresomni_httpc, omni_web
RPMPIGSTY0.2.01817161514omnigres_$v-
DEBPIGSTY0.2.01817161514postgresql-$v-omnigres-
OS / PGPG18PG17PG16PG15PG14
el8.x86_64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
el8.aarch64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
el9.x86_64PIGSTY MISSPIGSTY 20250507PIGSTY 20250507PIGSTY 20250507PIGSTY 20250507
el9.aarch64PIGSTY MISSPIGSTY 20250507PIGSTY 20250507PIGSTY 20250507PIGSTY 20250507
el10.x86_64PIGSTY MISSPIGSTY MISSPIGSTY MISSPIGSTY MISSPIGSTY MISS
el10.aarch64PIGSTY MISSPIGSTY MISSPIGSTY MISSPIGSTY MISSPIGSTY MISS
d12.x86_64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
d12.aarch64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
d13.x86_64PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108
d13.aarch64PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108
u22.x86_64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
u22.aarch64PIGSTY MISSPIGSTY 20250120PIGSTY 20250120PIGSTY 20250120PIGSTY 20250120
u24.x86_64PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108
u24.aarch64PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108PIGSTY 20251108

Build

You can build the RPM / DEB packages for omnigres using pig build:

pig build pkg omnigres         # build RPM / DEB packages

Install

You can install omnigres directly. First, make sure the PGDG and PIGSTY repositories are added and enabled:

pig repo add pgsql -u          # Add repo and update cache

Install the extension using pig or apt/yum/dnf:

pig install omnigres;          # Install for current active PG version
pig ext install -y omnigres -v 18  # PG 18
pig ext install -y omnigres -v 17  # PG 17
pig ext install -y omnigres -v 16  # PG 16
pig ext install -y omnigres -v 15  # PG 15
pig ext install -y omnigres -v 14  # PG 14
dnf install -y omnigres_18       # PG 18
dnf install -y omnigres_17       # PG 17
dnf install -y omnigres_16       # PG 16
dnf install -y omnigres_15       # PG 15
dnf install -y omnigres_14       # PG 14
apt install -y postgresql-18-omnigres   # PG 18
apt install -y postgresql-17-omnigres   # PG 17
apt install -y postgresql-16-omnigres   # PG 16
apt install -y postgresql-15-omnigres   # PG 15
apt install -y postgresql-14-omnigres   # PG 14

Create Extension:

CREATE EXTENSION omni_containers CASCADE;  -- requires: omni_httpc, omni_web

Usage

omni_containers: Docker container management

The omni_containers extension manages Docker container lifecycle from PostgreSQL. Requires Docker Engine API access (defaults to unix:///var/run/docker.sock).

Create and Start a Container

SELECT * FROM omni_containers.docker_container_create(
    'busybox',
    cmd  => 'echo Hello world',
    pull => true
);

Parameters: image (required), cmd, attach (default db.omni), start (default true), wait (default false), pull (default false), options (jsonb).

Container Logs

SELECT * FROM omni_containers.docker_container_logs('container_id');

Supports stdout, stderr, since, until, timestamps, tail parameters.

Execute Command in Container

SELECT * FROM omni_containers.docker_container_exec('container_id', 'ls -la');

Stop and Inspect

SELECT * FROM omni_containers.docker_container_stop('container_id');
SELECT info->'State'->'ExitCode' FROM omni_containers.docker_container_inspect('container_id') AS info;

List Docker Images

SELECT repo_tags FROM omni_containers.docker_images;

Full Workflow Example

WITH container AS (
    SELECT * FROM omni_containers.docker_container_create(
        'ghcr.io/yrashk/psql',
        cmd  => $$psql -c 'create table test ();'$$,
        wait => true, pull => true) AS id
)
SELECT
    omni_containers.docker_container_inspect(id)->'State'->'ExitCode' AS exit_code,
    omni_containers.docker_container_logs(id) AS logs
FROM container;

Last Modified 2026-03-12: add pg extension catalog (95749bf)