Conda: Difference between revisions
Line 236: | Line 236: | ||
* Create a shared Conda environment with <code>--prefix</code> to specify the path to use to store the conda environment | * Create a shared Conda environment with <code>--prefix</code> to specify the path to use to store the conda environment | ||
{{Term|location=flyon|cmd=<code class="command">conda create --prefix /srv/storage/</code><code class="replace">storage_name</code>@<code class="replace">server_hostname_(fqdn)/ENVNAME</code>}} | {{Term|location=flyon|cmd=<code class="command">conda create --prefix /srv/storage/</code><code class="replace">storage_name</code>@<code class="replace">server_hostname_(fqdn)/ENVNAME</code>}} | ||
* Activate the shared environment (share this command with the targeted users) | * Activate the shared environment (share this command with the targeted users) | ||
Line 244: | Line 245: | ||
** Users could potentially harm the environment by installing or removing packages. | ** Users could potentially harm the environment by installing or removing packages. | ||
** When installing additional packages, conda still stores them in the package cache located in your home directory. Use <code class="command">conda clean</code> as described above to clean those files. | ** When installing additional packages, conda still stores them in the package cache located in your home directory. Use <code class="command">conda clean</code> as described above to clean those files. | ||
* Create your environments by defaut in a group storage location | * Create your environments by defaut in a group storage location |
Revision as of 13:57, 15 June 2023
Note | |
---|---|
This page is actively maintained by the Grid'5000 team. If you encounter problems, please report them (see the Support page). Additionally, as it is a wiki page, you are free to make minor corrections yourself if needed. If you would like to suggest a more fundamental change, please contact the Grid'5000 team. |
Introduction
Conda is an open source package management system and environment management system for installing multiple versions of software packages and their dependencies and switching easily between them. It works on Linux, OS X and Windows, and was created for Python programs but can package and distribute any software.
The conda package and environment manager is included in all versions of Anaconda®, Miniconda, and Anaconda Repository. Conda is also available on conda-forge, a community channel.
Anaconda or Miniconda?
Anaconda contains a full distribution of packages while Miniconda is a condensed version that contains the essentials for standard purposes.
References
Conda usage
Conda initialization and activation
Conda initialization is the process of defining some shell functions that facilitate activating and deactivating Conda environments, as well as some optional features such as updating PS1 to show the active environment.
The conda shell function is mainly a forwarder function. It will delegate most of the commands to the real conda executable driven by the Python library.
There are two ways to activate conda:
- 1. occasionally : activate conda in your current shell
- 2. always : activate conda in your login shell environment permanently (this command modifies your .bashrc by adding conda setup directives)
The conda activate
or
conda deactivate
commands relies on the conda shell initialization to load/unload the corresponding conda environment variables to the current shell session.
By defaut, you are located in the base
Conda environment that correspond to the base installation of Conda.
If you’d prefer that conda’s base environment not be activated on startup, set the auto_activate_base parameter to false:
Verify your conda configuration with this command:
Look at all available configuration options with:
Conda environments
Conda allows you to create separate environments containing files, packages, and their dependencies that will not interact with other environments.
When you begin using conda, you already have a default environment named "base". You can create separate environments to keep your programs isolated from each other. Specifying the environment name confines conda commands to that environment.
- List all your environments
or
- Create a new environment
- Activate this environment before installing package
For further information:
- https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html
- Managing your data science project environments with Conda
Conda package installation
In its default configuration (the default Conda channel), Conda can install and manage the over 7,500 packages at https://repo.anaconda.com/pkgs/ that are built, reviewed, and maintained by Anaconda.
- Install specific version of package:
- Uninstall a package:
For more information:
Conda package installation from channels
Channels are the locations of the repositories where Conda looks for packages. Channels may point to a Cloud repository or a private location on a remote or local repository that you or your organization created. Useful channels are:
conda-forge
from https://conda-forge.org. It is free for all to use.nvidia
from https://anaconda.org/nvidia. It provides Nvidia's software.
To install a package from a specific channel:
- List all packages installed with their source channels
For more information:
Suggested reading
- Conda cheat sheet for current commands
- Getting Started with Conda
Conda on Grid'5000
Conda is already available in Grid'5000 as a module. You do not need to install Anaconda or Miniconda on Grid'5000 !
The module supplied in Grid'5000 is based on the miniconda distribution
Load Conda module
- To show the available versions:
- To make it available on a node or on a frontend, load the Conda module as follow (default version):
- Initialize Conda
As explained above, there are two methods to initialize conda in your shell: (1) as needed or (2) systematically As module allows you to install different versions of conda, we recommend the "as needed" method to ensure that your shell will contain the PATH corresponding to the loaded version of conda. The command is:
Create an environment
For example create environment <env_name>
(specify a Python version; otherwise, it is the module default version)
Load this environment
Install a package into
Exit from the loaded environment
Remove unused Conda environments
Warning | |
---|---|
Conda packages are installed in |
- To delete an environment
- To remove unused packages and the cache. Do not be concerned if this appears to try to delete the packages of the system environment (ie. non-local).
Use a Conda environment in a job
As seen in the previous section, the Conda environment is stored by default in user's homedir (at ~/.conda
). Once the environment is created and packages installed, it is usable on all nodes from the given site.
For interactive jobs
Load, init, and active you conda environment env_name
in an interactive job
For batch jobs
Load, init, and active you conda environment env_name
in a batch job
Warning | |
---|---|
As module command is not a real executable but a shell function, it must be executed in an actual shell to work. |
First prepare your conda environment on the frontend:
- load conda, conda init (to modify our
~/.bashrc
file) - conda creation of an environement
testconda
containinggcc
fromconda-forge
channel" - list installed packages with source info
fsiteA :
|
module load conda
conda install -c conda-forge gcc_linux-64 gxx_linux-64 |
- launch this commands and keep output result
In this example, we launch a job that does the same tasks but in batch job.
- The important step is to source shell environment to execute module and activate conda
fsiteA :
|
oarsub 'bash -l -c ". /etc/profile ; module load conda ; source ~/.bashrc ; conda activate testconda ; conda info ; conda list -n testconda --show-channel-url"' |
OAR_JOB_ID=1539228
- Is job finished ?
# Error: job 1539228 is not running. Its current state is Finishing.
- Compare output with the previous one : they should be identical
Advanced Conda environment operations
Synchronize Conda environments between Grid'5000 sites
- To synchronize a Conda directory from a siteA to a siteB:
To really do things, the --dry-run
argument has to be removed and siteB has to be replaced by a real site name.
You can use two different approaches to share Conda environments with other users.
Export an environment as a yaml file
- Export it as follow:
- Share it by putting the yaml file in your public folder
- Other users can create the environment from the
environment.yml
file
- Advantage : it prevents other users from damaging the environment if they add packages that could conflict with other packages and/or even delete packages that another user might need.
- Inconvenient : it's not a true shared environment. The environment is duplicated on other users' home directory. Any modification on one Conda environment will not be automatically replicated on others.
Use a group storage
Group Storage gives you the possibility to share a storage between multiple users. You can take advantage of a group storage to share a single Conda environment among multiple users.
- Create a shared Conda environment with
--prefix
to specify the path to use to store the conda environment
- Activate the shared environment (share this command with the targeted users)
- Advantage : It avoids storing duplicate packages and makes any modification accessible to all users
- Inconvenients :
- Users could potentially harm the environment by installing or removing packages.
- When installing additional packages, conda still stores them in the package cache located in your home directory. Use
conda clean
as described above to clean those files.
- Create your environments by defaut in a group storage location
You can modify you ~/.condarc
file to specify this location for conda environment and package installation as follow (change the location to suit your group and your convenience). Add this lines:
pkgs_dirs: - /srv/storage/storage_name@server_hostname_(fqdn)/conda_shared_envs/pkgs/ envs_dirs: - /srv/storage/storage_name@server_hostname_(fqdn)/conda_shared_envs/envs/
Mamba as an alternative to Conda
mamba is a reimplementation of the conda package manager in C++. Mamba is fully compatible with Conda packages and supports most of Conda's commands. It consists of:
- mamba: a Python-based CLI conceived as a drop-in replacement for conda, offering higher speed and more reliable environment solutions
- micromamba: a pure C++-based CLI, self-contained in a single-file executable
- libmamba: a C++ library exposing low-level and high-level APIs on top of which both mamba and micromamba are built
Mamba is relatively new and unpopular compared to Conda. That means there are probably more undiscovered bugs, and that new bugs may take longer to be discovered. mamba has to be considerate when using a devops chain in order to test and deploy an environment (i.e., docker images) with continuous integration pipelines. Conda has a reputation for taking time when dealing with complex sets of dependencies so CI jobs can take longer than they need to.
- Mamba installation when already have Conda
- Installing packages is similarly easy, example:
To go further:
Build your HPC-IA framework with conda
Here are some pointers to help you set up your software environment for HPC or AI with conda