salloc -A naiss2023-22-862 -t 03:30:00 -p core -n 1 --no-shell
1 Connect to UPPMAX
The first step of this lab is to open a ssh connection to UPPMAX. Please refer to Connecting to UPPMAX for instructions. Once connected to UPPMAX, return here and continue reading the instructions below.
2 Logon to a node
Usually you would do most of the work in this lab directly on one of the login nodes at UPPMAX, but we have arranged for you to have one core each for better performance. This was covered briefly in the lecture notes.
Check which node you got when you booked resources this morning (replace username with your UPPMAX username)
$ squeue -u username
should look something like this
dahlo@rackham2 work $ squeue -u dahlo
JOBID PARTITION NAME USER ST TIME NODES NODELIST(REASON)
3132376 core sh dahlo R 0:04 1 r292
dahlo@rackham2 work $
where r292 is the name of the node I got (yours will probably be different). Note the numbers in the Time column. They show for how long the job has been running. When it reaches the time limit you requested (7 hours in this case) the session will shut down, and you will lose all unsaved data. Connect to this node from within UPPMAX.
$ ssh -Y r292
If the list is empty you can run the allocation command again and it should be in the list:
There is a UPPMAX specific tool called jobinfo
that supplies the same kind of information as squeue
that you can use as well ($ jobinfo -u username
).
3 Copy files for lab
Now, you will need some files. To avoid all the course participants editing the same file all at once, undoing each other’s edits, each participant will get their own copy of the needed files. The files are located in the folder /sw/courses/ngsintro/linux/uppmax_tutorial
Next, copy the lab files from this folder. -r
means recursively, which means all the files including sub-folders of the source folder. Without it, only files directly in the source folder would be copied, NOT sub-folders and files in sub-folders.
Remember to use tab-complete to avoid typos and too much writing.
cp -r <source> <destination>
cp -r /sw/courses/ngsintro/linux/uppmax_tutorial /proj/naiss2023-22-862/nobackup/username
Have a look in /proj/naiss2023-22-862/nobackup/<username>/uppmax_tutorial.
cd /proj/naiss2023-22-862/nobackup/username/uppmax_tutorial
$ ll
total 128K
drwxrwxr-x 2 dahlo dahlo 2,0K May 18 16:21 .
drwxrwxr-x 4 dahlo dahlo 2,0K May 18 15:34 ..
-rwxrwxr-x 1 dahlo dahlo 1,2K May 18 16:21 data.bam
-rw-rw-r-- 1 dahlo dahlo 232 May 18 16:21 job_template
$
4 Run programs
Among the files that were copied is data.bam. BAM is a popular format to store aligned sequence data, but since it is a, so called, binary format it doesn’t look that good if you are human. Try it using less:
$ less data.bam
Not so pretty.. Luckily for us, there is a program called samtools that is made for reading BAM files. To use it on UPPMAX we must first load the module for samtools. Try starting samtools before loading the module.
$ samtools
-bash: samtools: command not found
$
That did not work, try it again after loading the module:
$ module load bioinfo-tools samtools/1.10
$ samtools
Program: samtools (Tools for alignments in the SAM format)
Version: 1.10 (using htslib 1.10)
Usage: samtools <command> [options]
Commands:
-- Indexing
dict create a sequence dictionary file
faidx index/extract FASTA
fqidx index/extract FASTQ
index index alignment
-- Editing
calmd recalculate MD/NM tags and '=' bases
fixmate fix mate information
reheader replace BAM header
targetcut cut fosmid regions (for fosmid pool only)
addreplacerg adds or replaces RG tags
markdup mark duplicates
-- File operations
collate shuffle and group alignments by name
cat concatenate BAMs
merge merge sorted alignments
mpileup multi-way pileup
sort sort alignment file
split splits a file by read group
quickcheck quickly check if SAM/BAM/CRAM file appears intact
fastq converts a BAM to a FASTQ
fasta converts a BAM to a FASTA
-- Statistics
bedcov read depth per BED region
coverage alignment depth and percent coverage
depth compute the depth
flagstat simple stats
idxstats BAM index stats
phase phase heterozygotes
stats generate stats (former bamcheck)
-- Viewing
flags explain BAM flags
tview text alignment viewer
view SAM<->BAM<->CRAM conversion
depad convert padded BAM to unpadded BAM
All modules are unloaded when you disconnect from UPPMAX, so you will have to load the modules again every time you log in. If you load a module in a terminal window, it will not affect the modules you have loaded in another terminal window, even if both terminals are connected to UPPMAX. Each terminal is independent of the others.
To use samtools to view a BAM file, use the following line.
$ samtools view -h data.bam
@HD VN:1.0 SO:coordinate
@SQ SN:chr1 LN:249250621
@SQ SN:chr10 LN:135534747
@SQ SN:chr11 LN:135006516
@SQ SN:chr12 LN:133851895
@SQ SN:chr13 LN:115169878
@SQ SN:chr14 LN:107349540
@SQ SN:chr15 LN:102531392
@SQ SN:chr16 LN:90354753
-h
also print the BAM file’s header, which is the rows starting with @
signs in the beginning of the file. These lines contain so called metadata; information about the data stored in the file. It contain things like which program was used to generate the BAM file and which chromosomes are present in the file. Try running the command without the -h
to see the difference.
The not-binary version (ASCII, or text version) of a BAM file is called a SAM file, which was just printed directly into the terminal window. The SAM file is not to much use for us printed in the terminal window, aesthetics aside. It is probably much better to have the SAM file saved as an actual file, something that is very easy to do. Any text that is printed to the terminal can be saved to a file instead of the terminal window using a ‘crocodile mouth’, >
$ program arguments > outfile
which will launch a program named program, supply it with the argument arguments, and write any output that would have been printed to the screen to the file outfile instead.
To use this on samtools,
$ samtools view -h data.bam > data.sam
Look at the created file:
$ ll
The SAM file is now human readable. Try viewing it with less
:
$ less data.sam
You can also edit the file with nano:
$ nano data.sam
Try deleting the whole last line in the file, save it, and exit nano.
5 Modules
To view which module you have loaded at the moment, type
$ module list
Currently Loaded Modules:
1) uppmax 2) bioinfo-tools 3) samtools/1.10
Let’s say that you want to make sure you are using the latest version samtools. Look at which version you have loaded at the moment (samtools/1.10
).
Now type
$ module avail
to see which programs are available at UPPMAX. Can you find samtools in the list? Which is the latest version of samtools available at UPPMAX?
To change which samtools module you have loaded, you have to unload the the module you have loaded and then load the other module. To unload a module, use
$ module unload <module name>
Look in the list from $ module list
to see the name of the module you want to unload. When the old module is unloaded, load samtools/0.1.19
(or try with the latest samtools module!).
6 Submitting a job
Not all jobs are as small as converting this tiny BAM file to a SAM file. Usually the BAM files are several gigabytes, and can take hours to convert to SAM files. You will not have reserved nodes waiting for you to do something either, so running programs is done by submitting a job to the queue system. What you submit to the queue system is a script file that will be executed as soon as it reaches the front of the queue. The scripting language used in these scripts is bash, which is the same language as you usually use in a terminal i.e. everything so far in the lecture and lab has been in the bash language (cd
, ls
, cp
, mv
, etc.).
Have a look at job_template in your uppmax_tutorial folder.
$ less job_template
#! /bin/bash -l
#SBATCH -A gXXXXXXX
#SBATCH -p core
#SBATCH -J Template_script
#SBATCH -t 01:00:00
# load some modules
module load bioinfo-tools
# go to some directory
cd /proj/gXXXXXXX/nobackup/
# do something
echo Hello world!
Edit this file to make the job convert data.bam to a SAM file named jobData.sam. Remember how the queue works? Try to approximate the runtime of the job (almost instant in this case) and increase it by ~50%, and use that time approximation when writing your script file. Longer jobs will wait longer in the queue because it is harder to fit them into gaps in the queue! Also remember to change the project ID to match this course occasion.
Remember, just write the command you would run if you were sitting by the computer, i.e. load the correct modules, go to the correct folder, and run samtools the right way.
Submit your job using sbatch
:
$ sbatch job_template
7 Job queue
If you want to know how your jobs are doing in the queue, you can check their status with $ squeue -u username
or $ jobinfo -u username
.
Rewrite the previous sbatch file so that you book 3 days of time, and to use a node instead of a core. This will cause your job to stand in the queue for a bit longer, so that we can have a look at it while it is queuing. Submit it to the queue and run jobinfo
.
$ jobinfo -u username
CLUSTER: rackham
Running jobs:
JOBID PARTITION NAME USER ACCOUNT ST START_TIME TIME_LEFT NODES CPUS NODELIST(REASON)
3134399 devcore dahlo g20XXXXX R 2018-05-18T16:32:54 59:25 1 1 r483
Nodes in use: 462
Nodes in devel, free to use: 2
Nodes in other partitions, free to use: 4
Nodes available, in total: 468
Nodes in test and repair: 13
Nodes, otherwise out of service: 5
Nodes, all in total: 486
Waiting jobs:
JOBID POS PARTITION NAME USER ACCOUNT ST START_TIME TIME_LEFT PRIORITY CPUS NODELIST(REASON) FEATURES DEPENDENCY
3134401 221 core Template_script dahlo g20XXXXX PD N/A 1:00:00 100000 1 (None) (null)
Waiting bonus jobs:
$
If you look under the heading “Waiting jobs:” you’ll see a list of all the jobs you have in the queue that have not started yet. The most interesting column here is the POS column, which tells you which position in the queue you have (221 in my example). When you reach the first place, your job will start as soon as there are the resources you have asked for.
In our case, we are not really interested in running this job at all. Let’s cancel it instead. This can be done with the command scancel
. Syntax:
$ scancel <job id>
You see the job id number in the output from jobinfo
or squeue
.
$ scancel 3134401
8 Interactive jobs
Sometimes it is more convenient to work interactively on a node instead of submitting your work as a job. Since you will not have the reservations we have during the course, you will have to book a node using the interactive
command. Syntax:
$ interactive -A <project id> -t <time> -p <node or core>
This will create a booking for you which has a higher priority than the jobs submitted with sbatch
. That means that they will start faster, but only if the booking is shorter than 12 hours. If the booking is longer than 12 hours, it will get the standard priority. When the job starts you will be transferred to the node you got automatically. No need to look which node you got using sbatch and then ssh:ing to it.
Try closing down your current session on the reserved node you connected to in the beginning of the lab by typing exit
. Then make a new booking using interactive,
interactive -A naiss2023-22-862 -t 02:30:00 -p core
Congratulations, you are now ready to be let loose on the cluster!
9 Extra
Extra material if you finish too fast.
9.1 The devel queue
If it is a really big job, it might be in the queue for a day or two before it starts, so it is important to know that the first thing it does is not crashing because you made a typo on line 7. One way to test this is to open a new connection to UPPMAX, and line by line try your code. Copy-paste (Ctrl+Shift+c and Ctrl+Shift+v in the terminal window) to make sure it’s really the code in the script you are trying.
If your script is longer than a couple of lines, this approach can be tiring. There are 12 nodes at UPPMAX that are dedicated to do quick test runs, which have a separate queue called devel. They are available for use more or less all the time since not very many are using them. To avoid people abusing the free nodes for their analysis, there is a 1 hour time limit for jobs on them. To submit jobs to this short testing queue, change -p
to devel instead of node or core, and make sure -t
is set to maximum 01:00:00. Try submitting the samtools sbatch file we used earlier to the devel queue and run it again.
9.2 Info about finished jobs
If you want information about jobs you have run in the past, you can use the tool finishedjobinfo
. It will print information about the jobs you have run lately.
Fun things to look for in this information is jobstate which will tell you if the program reported any error while running. If so, jobstate will be FAILED and you could suspect that something didn’t go according to the plan, and you should check the output from that job run (the slurm-.out file) and see if you can solve the error.
Other good things to look for could be:
- maxmemory_in_GiB: tells you how much memory the program used at most.
- runtime: tells you how long time the program ran before it finished/failed
9.3 Time and space
Remember the commands uquota
(show how much of your storage space you are using) and projinfo
(shows you how much of your allocated time you have used) from the lecture? Try running them and see how you are doing.