HPC/Module naming scheme 2016: Difference between revisions
< HPC
Jump to navigation
Jump to search
Line 32: | Line 32: | ||
</source> | </source> | ||
: Apply the changes shown in the [[#Rules]] section. | : Apply the changes shown in the [[#Rules]] section. | ||
* Tell CentOS-5 nodes to | * Tell CentOS-5 nodes to offer the new-style module catalog instead of the old one. To do so, simply create an empty customization file: | ||
<source lang="bash"> | <source lang="bash"> | ||
touch ~/.modules-el6 | touch ~/.modules-el6 | ||
Line 42: | Line 42: | ||
=== Configure in dedicated files === | === Configure in dedicated files === | ||
It is perhaps cleaner to perform the module selection in dedicated | It is perhaps cleaner to perform the module selection in files dedicated for each CentOS release, so that you can better address possible incompatibilities. | ||
To migrate your existing configuration: | |||
* Move your previous module selections into a conspicuously named but otherwise unused file, e.g., <code>.modules-el5.inactive</code>. | * Move your previous module selections into a conspicuously named but otherwise unused file, e.g., <code>.modules-el5.inactive</code>. | ||
<source lang="bash"> | <source lang="bash"> |
Revision as of 18:30, October 9, 2015
Configuration files used
You have files: .bashrc and … |
Remark | CentOS-5 uses: | CentOS-6 uses: | |||
---|---|---|---|---|---|---|
module names | files | module names | files | |||
– | – | Starting situation. | old | .bashrc only | new | .bashrc only |
– | .modules-el6 | Switch over, recommended. | new | .modules-el6 and .bashrc | .modules-el6 and .bashrc | |
.modules-el5 | – | Avoid! – file ignored on EL6. | old | .modules-el5 and .bashrc | .bashrc only | |
.modules-el5 | .modules-el6 | For advanced users. | old | .modules-el5 and .bashrc | .modules-el6 and .bashrc |
Migration to new-style module names
Rules
Adapt module
commands present in your shell "dot"-files and job scripts to new-style names as follows:
- Remove version numbers from module names of the old-style
packagename/version
, leaving onlypackagename
. This is the recommended approach, as you will automatically benefit from future updates. - To insist on a specific version for a package in the new style, use the form
packagename/compilername/version
orpackagename/mpiname/compilername/version
as appropriate. To see available flavors and versions, separately run the commandmodule avail packagename
.
Configure in .bashrc
To switch over to new-style module names on both CentOS releases you could continue making all your module choices in ~/.bashrc
.
vi .bashrc
# or:
nano .bashrc
- Apply the changes shown in the #Rules section.
- Tell CentOS-5 nodes to offer the new-style module catalog instead of the old one. To do so, simply create an empty customization file:
touch ~/.modules-el6
Configure in dedicated files
It is perhaps cleaner to perform the module selection in files dedicated for each CentOS release, so that you can better address possible incompatibilities. To migrate your existing configuration:
- Move your previous module selections into a conspicuously named but otherwise unused file, e.g.,
.modules-el5.inactive
.
cd # Go to home directory
grep -A 1 module .bashrc > .modules-el5.inactive
- Duplicate the file.
cp .modules-el5.inactive .modules-el6
- Adapt contents to new module names, just as shown for
.bashrc
in the previous section. Clean up errant lines that the grep above might have included.
vi .modules-el6
# or:
nano .modules-el6
- Apply the changes shown in the #Rules section.
- Edit
~/.bashrc
and remove all lines with "module" commands.
vi .bashrc
- Test.
bash -l # open a sub-shell (option is lowercase L)
module list
exit # leave the sub-shell
CentOS-dependent module selection
If you encounter difficulties with making your module selection work simultaneously for CentOS-5 and CentOS-6, use separate configurations instead.
- Follow the steps as above.
- Re-activate the older module selection.
- Test.
cd # Go to home directory
mv .modules-el5.inactive .modules-el5
vi .modules-el5 # clean up errant lines
# Test
exec bash -l
module list