Skip to main content

A Snakemake executor plugin for submitting jobs to SGE/UGE/OGS clusters.

Project description

snakemake-executor-plugin-sge

A Snakemake executor plugin for Sun Grid Engine (SGE), Univa Grid Engine (UGE), and Open Grid Scheduler (OGS) clusters.

Features

  • Every job is an array job – singletons become -t 1-1, batches become -t 1-N. One submission path, one tracking path, no special cases.
  • Group jobs as a single array job – Snakemake group jobs (several rules bundled together) are submitted as one qsub call.
  • Rich qsub flag coverage – queue, project, parallel environment, wall time, memory (per-slot and total), priority, requeue, reservation, notify, mail, hold_jid, task concurrency, env-var export, join logs, and arbitrary extra flags.
  • Per-rule resource overrides – any global setting can be overridden via rule resources: (e.g. sge_queue, sge_pe, sge_extra, …).
  • Two-stage status pollingqstat for in-flight jobs, qacct for completed jobs; configurable retries and optional qacct disabling.
  • Clean log management – per-task stdout/stderr, optional auto-delete on success, age-based rotation.

Installation

pip install snakemake-executor-plugin-sge

Quick start

snakemake --executor sge --jobs 100

Common options

CLI flag Default Description
--sge-queue Default queue (-q)
--sge-pe Parallel environment for multi-thread jobs
--sge-project Project (-P)
--sge-export-env True Export environment (-V)
--sge-join-logs False Merge stdout+stderr (-j y)
--sge-requeue Requeue on failure (-r y/n)
--sge-reservation Resource reservation (-R y/n)
--sge-notify False Send notify signal
--sge-mail-on Mail events (b, e, a, s, n)
--sge-mail-address Mail address (-M)
--sge-hold-jid Hold until job(s) finish
--sge-array-limit 75000 Max tasks per qsub -t call
--sge-task-concurrency Max concurrent array tasks (-tc)
--sge-logdir .snakemake/sge_logs Log directory
--sge-keep-successful-logs False Keep logs for successful jobs
--sge-use-qacct True Use qacct for finished-job detection
--sge-extra Raw extra qsub flags (global)
--sge-jobname-prefix Prefix for SGE job names

Per-rule resource overrides

rule my_rule:
    resources:
        runtime        = 120,          # minutes → h_rt=02:00:00
        mem_mb         = 8192,         # total memory (divided by threads per slot)
        mem_mb_per_cpu = 2048,         # per-slot memory (takes precedence)
        threads        = 4,
        sge_queue      = "highmem.q",
        sge_pe         = "smp",
        sge_project    = "myproject",
        sge_extra      = "-l gpu=1",   # arbitrary extra qsub flags
        sge_resources  = {"h_cpu": "24:00:00", "arch": "lx-amd64"},
        sge_join_logs  = True,
        sge_requeue    = True,
        sge_priority   = -100,
        sge_notify     = True,
        sge_mail_on    = "e",
        sge_mail_address = "me@example.com",
        sge_hold_jid   = "12345",
        sge_task_concurrency = 8,
        sge_export_env = False,
    threads: 4
    shell: "..."

Array-job design

Every qsub submission uses qsub -t start-end. Execution commands are stored in a JSON file on the shared filesystem before qsub is called. The submission script reads $SGE_TASK_ID, looks up the compressed command, and evaluates it. This avoids command-line length limits and all heredoc/quoting problems.

License

MIT

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

snakemake_executor_plugin_sge-0.5.9.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

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

snakemake_executor_plugin_sge-0.5.9-py3-none-any.whl (24.0 kB view details)

Uploaded Python 3

File details

Details for the file snakemake_executor_plugin_sge-0.5.9.tar.gz.

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.5.9.tar.gz
Algorithm Hash digest
SHA256 3b7f4dc3fa18abd890ebdd258838a353c80f00d54f15d6c09ab391b1ca88a312
MD5 ba0d7bea0b605e7aecb6e9f6229cac4d
BLAKE2b-256 e06f87c681ad56d35be4dfd6ee2604c46156097510fd705935df9583d7b74b0d

See more details on using hashes here.

File details

Details for the file snakemake_executor_plugin_sge-0.5.9-py3-none-any.whl.

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.5.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f46a9fc7a453b5eca420b9152f2b39f7d9ee31b9fac8e18cb0352a479848e965
MD5 cc35e42cd9cac890ef9d692bb65ed771
BLAKE2b-256 03756c2157e03c7e5fdfe4c2312a09d6384f7455d5476e5048c07d340db5ad9d

See more details on using hashes here.

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