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.6.1.tar.gz (22.7 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.6.1-py3-none-any.whl (23.9 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.1.tar.gz
Algorithm Hash digest
SHA256 bf15078c4ddf23055245c102e8ff471014b4cf750ae03726a39127a044c9a925
MD5 6d06d09722e0076dee35719b8ac3732c
BLAKE2b-256 d921b66852d18275226cebec1842b26d2543504724f3720373a3eec2a13b04f6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 29b57c0532eb7986e144df61d930398a67b5af07d9da556c176be6822d58d9fd
MD5 c0abe504837f0c0e2f0e07eab3c6e870
BLAKE2b-256 8d9fbe8de4b7480135db67a10f7a073d8c21f70cec7f73b3b7f8e5365eb3c907

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