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.2.tar.gz (23.0 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.2-py3-none-any.whl (24.2 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.2.tar.gz
Algorithm Hash digest
SHA256 1b70417db9f2c81fa20ff37111da29c9579042a6b8460ab9c3e288e2277dcb21
MD5 30da0c5d7757a18aba17cabf2cf9ad76
BLAKE2b-256 8ab06947c3673f107d71f87877a18809f09169b99d2eb44b2bed68c90de2a462

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0482cac1aaf053a9d715cf5c773a555162e046128675582291a7091a597a1943
MD5 c4c219440705d24aa6515a102b3fd669
BLAKE2b-256 5f6ccd6afd0ed89d1a79d35f330fb019f9efb596ad9348cebeeb757ab774ee5d

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