-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathsubmitOGE.pl
78 lines (69 loc) · 3.24 KB
/
submitOGE.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#!/usr/bin/env perl
use strict;
use warnings;
use Data::Dumper;
my %programs = ();
$programs{amphora2} = {ram => 10}; #ram in GB
$programs{focus} = {ram => 10}; #ram in GB
$programs{metaphlan2} = {ram => 10}; #ram in GB
$programs{metaphyler} = {ram => 40}; #ram in GB
$programs{metaphyler_nx} = {ram => 40, ncores => 20}; #ram in GB
$programs{motu} = {ram => 10}; #ram in GB
$programs{phylosift} = {ram => 40}; #ram in GB
$programs{commonkmers} = {ram => 45, ncores => 4, mounts => [{host => '/vol/projects/sjanssen/CAMI/ReferenceData/commonkmers/', container => '/exchange/db/', permissions => 'ro'}]}; #ram in GB
$programs{quickr} = {ram => 20, ncores => 4}; #ram in GB
$programs{taxypro} = {ram => 15}; #ram in GB
$programs{tipp} = {ram => 50, ncores => 20}; #ram in GB
$programs{metacv} = {ram => 100, ncores => 4}; #ram in GB
my ($toolname, $justprint) = @ARGV;
die "usage: perl $0 <toolname> [justprint]\n toolname = name of the profiling tool to run on the cluster.\n justprint = if defined, just print the content of the cluster script to STDOUT, but don't actually submit.\n" if (@ARGV < 1 || @ARGV > 2);
my $script = createScript($ARGV[0]);
if (defined $script) {
if (defined $justprint) {
print $script;
} else {
my $scriptfilename = "tmp_clusterscript.sh";
open (OUT, "> $scriptfilename") || die "cannot write: $!";
print OUT $script;
close (OUT);
#~ print qx(qsub $scriptfilename);
print qx(qsub -l hostname=bioinf003 $scriptfilename);
unlink $scriptfilename;
}
}
sub createScript {
my ($toolname) = @_;
my $found = 'false';
foreach my $name (keys(%programs)) {
if ($name eq $toolname) {
$found = 'true';
last;
}
}
die "No task with name '$toolname' in database.\nAvailable tools are: '".join("', '", sort keys(%programs))."'.\n" if ($found eq 'false');
my $pathOfDockerfiles = '/vol/projects/sjanssen/docker_profiling_tools';
my $resultdir = "/vol/projects/sjanssen/dockerruns";
my $ncores = 4;
$ncores = $programs{$toolname}->{ncores} if (exists $programs{$toolname}->{ncores});
my $SCRIPT = '#!/bin/bash'."\n\n";
$SCRIPT .= '#$ -S /usr/bin/bash'."\n";
$SCRIPT .= '#$ -N '.$toolname.''."\n";
$SCRIPT .= '#$ -e '.$resultdir.'/ERR/'."\n";
$SCRIPT .= '#$ -o '.$resultdir.'/OUT/'."\n";
mkdir $resultdir."/".$toolname if ((not -d $resultdir."/".$toolname) && (not defined $justprint));
$SCRIPT .= '#$ -pe multislot '.$ncores."\n";
$SCRIPT .= '#$ -l virtual_free='.($programs{$toolname}->{ram}/$ncores).'g'."\n";
$SCRIPT .= '#$ -l mem_free='.($programs{$toolname}->{ram}/$ncores).'g'."\n";
$SCRIPT .= '#$ -cwd'."\n\n";
$SCRIPT .= 'uname -a'."\n";
$SCRIPT .= 'cd '.$pathOfDockerfiles."\n";
$SCRIPT .= 'docker build -f '.$pathOfDockerfiles.'/'.$toolname.'/Dockerfile_'.$toolname.' -t '.$toolname.' .'."\n";
$SCRIPT .= 'docker run --env="NCORES='.$ncores.'" --rm=true --memory='.$programs{$toolname}->{ram}.'g --memory-swap=-1 --cpuset-cpus='.$ncores." \\\n";
$SCRIPT .= '-v "/vol/projects/sjanssen/CAMI/:/exchange/input:ro"'." \\\n";
$SCRIPT .= '-v "'.$resultdir.'/'.$toolname.':/exchange/output:rw"'." \\\n";
foreach my $mount (@{$programs{$toolname}->{mounts}}) {
$SCRIPT .= '-v "'.$mount->{host}.":".$mount->{container}.":".$mount->{permissions}.'"'." \\\n";
}
$SCRIPT .= '-t '.$toolname."\n";
return $SCRIPT."\n";
}