From 9b62e1a7d0e5f61439596d6ef0a9f68fcecf24ea Mon Sep 17 00:00:00 2001 From: Abhinav Sharma Date: Tue, 12 Mar 2024 17:22:34 -0300 Subject: [PATCH 1/2] add snippet to accommodate when a host volume is specified [ci skip] --- .../nextflow/nomad/executor/NomadService.groovy | 15 +++++++++++++-- .../src/test/nextflow/nomad/NomadDSLSpec.groovy | 4 ++-- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy b/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy index 87db205..18f9ec7 100644 --- a/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy +++ b/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy @@ -69,7 +69,7 @@ class NomadService implements Closeable{ protected Resources getResources(TaskRun task) { final DEFAULT_CPUS = 1 - final DEFAULT_MEMORY = "300.MB" + final DEFAULT_MEMORY = "500.MB" final taskCfg = task.getConfig() final taskCores = !taskCfg.get("cpus") ? DEFAULT_CPUS : taskCfg.get("cpus") as Integer @@ -108,7 +108,9 @@ class NomadService implements Closeable{ name: "group", tasks: [ task ] ) - if( config.jobOpts.volumeSpec){ + + + if( config.jobOpts.volumeSpec.type == NomadConfig.VOLUME_CSI_TYPE){ taskGroup.volumes = [:] taskGroup.volumes[config.jobOpts.volumeSpec.name]= new VolumeRequest( type: config.jobOpts.volumeSpec.type, @@ -117,6 +119,15 @@ class NomadService implements Closeable{ accessMode: "multi-node-multi-writer" ) } + + if( config.jobOpts.volumeSpec.type == NomadConfig.VOLUME_HOST_TYPE){ + taskGroup.volumes = [:] + taskGroup.volumes[config.jobOpts.volumeSpec.name]= new VolumeRequest( + type: config.jobOpts.volumeSpec.type, + source: config.jobOpts.volumeSpec.name, + ) + } + return taskGroup } diff --git a/plugins/nf-nomad/src/test/nextflow/nomad/NomadDSLSpec.groovy b/plugins/nf-nomad/src/test/nextflow/nomad/NomadDSLSpec.groovy index 72a83bc..2e63adf 100644 --- a/plugins/nf-nomad/src/test/nextflow/nomad/NomadDSLSpec.groovy +++ b/plugins/nf-nomad/src/test/nextflow/nomad/NomadDSLSpec.groovy @@ -146,7 +146,7 @@ class NomadDSLSpec extends Dsl2Spec{ then: thrown(AbortRunException) //it fails because no real task is executed - submitted - summary +// submitted +// summary } } From 0c8a4cbf5125c89b180b43630d84aafcb25f0cc7 Mon Sep 17 00:00:00 2001 From: Abhinav Sharma Date: Tue, 12 Mar 2024 17:55:15 -0300 Subject: [PATCH 2/2] add defaults for task restart/reschedule policy [ci skip] --- .../nextflow/nomad/executor/NomadService.groovy | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy b/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy index 18f9ec7..8e92e66 100644 --- a/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy +++ b/plugins/nf-nomad/src/main/nextflow/nomad/executor/NomadService.groovy @@ -25,7 +25,9 @@ import io.nomadproject.client.models.Job import io.nomadproject.client.models.JobRegisterRequest import io.nomadproject.client.models.JobRegisterResponse import io.nomadproject.client.models.JobSummary +import io.nomadproject.client.models.ReschedulePolicy import io.nomadproject.client.models.Resources +import io.nomadproject.client.models.RestartPolicy import io.nomadproject.client.models.Task import io.nomadproject.client.models.TaskGroup import io.nomadproject.client.models.TaskGroupSummary @@ -103,10 +105,18 @@ class NomadService implements Closeable{ } TaskGroup createTaskGroup(TaskRun taskRun, List args, Mapenv){ + final TASK_RESCHEDULE_ATTEMPTS = 0 + final TASK_RESTART_ATTEMPTS = 0 + + final ReschedulePolicy taskReschedulePolicy = new ReschedulePolicy().attempts(TASK_RESCHEDULE_ATTEMPTS) + final RestartPolicy taskRestartPolicy = new RestartPolicy().attempts(TASK_RESTART_ATTEMPTS) + def task = createTask(taskRun, args, env) def taskGroup = new TaskGroup( name: "group", - tasks: [ task ] + tasks: [ task ], + reschedulePolicy: taskReschedulePolicy, + restartPolicy: taskRestartPolicy ) @@ -139,6 +149,7 @@ class NomadService implements Closeable{ final workingDir = task.workDir.toAbsolutePath().toString() final taskResources = getResources(task) + def taskDef = new Task( name: "nf-task", driver: DRIVER,