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.3.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.3-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.3.tar.gz
Algorithm Hash digest
SHA256 4a8e5ae83513301f8a3f51444c01afcdb4ebe4b583819b6123ec4bbdfe64251d
MD5 c4b577735117b6b62ecb6ce10430f6d8
BLAKE2b-256 35c8a108b04d315fcb97d26937f64fc9c554e1a61a8f71a1f5a7c5ada4e9c795

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for snakemake_executor_plugin_sge-0.6.3-py3-none-any.whl
Algorithm Hash digest
SHA256 73f51aeca9e96d86cf76c90120895b1769ad6e4bf584c958f6bcca38f95f47b2
MD5 7c374c8a5eb39f1c24810a956222bdd1
BLAKE2b-256 8709a6386f49c5782451c3e8a3f74053911f2e2af009e39202a32b4e043095f5

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