Setting TMPDIR

From HPCwiki
Revision as of 15:51, 13 December 2013 by Bohme001 (talk | contribs)
Jump to navigation Jump to search

Note: all nodes are partioned with a large /local (+- 400G), /tmp is much smaller!

Many programs require writing intermediary or temporary information. A process may even require writing to a temporary location without a user knowing it. For instance, the command sort, part of the bash toolkit, requires a lot of temporary file space when sorting large volumes of data. Often programs take the system default, which is usually /tmp on Linux systems. The /tmp partition is however often too limited in size and can get filled up. When this happens all users that require write access to /tmp will experience problems in running jobs, which can range from unexpected quitting of processes, to erroneous output.

Users can set a custom temporary folder location by setting the TMPDIR environment variable. A custom temporary folder location is best placed in the 'scratch' space on the /lustre filesystem, because this will ensure periodic tidying up of the custom temporary directory thereby reducing the opportunity for very large temporary files that have gone unnoticed to remain on the filesystem. In addition, this is in line with protocols for the default system temporary directory /tmp as this directory is also periodically purged of older files.

First, create a temporary directory on user designated space on on the 'scratch' partition: <source lang='bash'> mkdir /lustre/scratch/WUR/ABGC/[user]/tmp </source>

Set the TMPDIR variable to point at the custom directory in either ~/.bash_profile or ~/.bashrc using a command-line editor of choice (vi, emacs, nano, etc), adding the following line of code: <source lang='bash'> export TMPDIR=/lustre/scratch/WUR/ABGC/[user]/tmp </source>

The temporary directory will be set to the custom location once you log in. For the current open terminal to set the new location immediately, without need to log out and in again: <source lang='bash'> source ~/.bash_profile </source>