mamba is a reimplementation of the conda package manager in C++.
parallel downloading of repository data and package files using multi-threading
libsolv for much faster dependency solving, a state of the art library used in the RPM package manager of Red Hat, Fedora and OpenSUSE
core parts of mamba are implemented in C++ for maximum efficiency
At the same time, mamba utilizes the same command line parser, package installation and deinstallation code and transaction verification routines as conda to stay as compatible as possible.
mamba is part of the conda-forge ecosystem, which also consists of quetz, an open source conda package server.
It can significantly reduce your CI setup time by:
Using micromamba, which takes around 1 s to install.
Caching package downloads.
Caching entire conda environments.
Differences with conda
While mamba and micromamba are generally a drop-in replacement for conda there are some differences:
mamba and micromamba normalize MatchSpec strings to the simplest form, whereas conda use a more verbose form
This can lead to slight differences in the output of conda env export and mamba env export.
The Mamba project uses semantic versioning of the form MAJOR.MINOR.PATCH.
While we try to keep things stable for users, we also need to make breaking changes to improve
Mamba and reduce technical debt.
Future versions of Mamba may give stronger guarantees.
libmamba (C++)
We are not aware of consumers of the C++ API, so we give ourselves room for improvements.
For libmamba, the term backward compatible is understood as follows:
ABI backward compatible means that you can replace the library binary files without recompiling
your code with the updated headers.
The observed behavior will be the same, except for bugs (disappearing, hopefully) and performance.
API backward compatible means that you must recompile your code with the new library
version code, but you won’t need to change your code, just re-build it.
This applies as long as you did not use any declaration understood to be private, for instance
in the detail sub-namespaces.
The observed behavior will be the same, except for bugs (disappearing, hopefully) and performance.
When declarations are deprecated but not removed and still functional, we consider it also
backward compatible, as only the observed behavior during compilation changes.
With this in mind, libmamba offers the following guarantees:
PATCH releases are API and ABI backward compatible;
MINOR releases are API compatible for declarations in mamba/api,
They can break API elsewhere and ABI anywhere;
MAJOR releases make no guarantees.
libmambapy (Python)
For libmambapy, the term API backward compatible implies that your Python code will work the
same for a newer version of libmambapy as long as you did not use any declaration understood to
be private, for instance accessed with a name starting with an _.
The observed behavior will be the same, except for bugs (disappearing, hopefully) and performance.
When declarations are deprecated but not removed and still functional, we consider it also
backward compatible, as the behavior is only observable when activating Python
DeprecationWarning, which is usually only activated in development.
With this in mind, libmambapy offers the following guarantees:
PATCH releases are API backward compatible;
MINOR releases are API backward compatible;
MAJOR releases make no guarantees.
mamba and micromamba (executables)
For executables, the term backward compatible applies to programmable inputs and outputs and means
that your code (including shell scripts) will work with newer versions of the executable without
modifications.
Programmable inputs/outputs include executable name, command line arguments, configuration files,
environment variables, JSON command line outputs, and files created.
It excludes human-readable output and error messages, and thus deprecation warnings written
in the human-readable output.
With this in mind, mamba and micromamba offer the following guarantees:
PATCH releases are backward compatible;
MINOR releases are backward compatible;
MAJOR releases make no guarantees.
Support us
Only mamba and micromamba 2.0 and later are supported and are actively developed.
The 1.x branch is only maintained for addressing security issues such as CVEs.
For questions, you can also join us on the QuantStack Chat
or on the Conda channel (note that this project is not officially affiliated with conda or Anaconda Inc.).
License
We use a shared copyright model that enables all contributors to maintain the copyright on their contributions.
This software is licensed under the BSD-3-Clause license. See the LICENSE file for details.
Biweekly Dev Meeting
We have videoconference meetings every two weeks where we discuss what we have been working on and get feedback from one another.
Anyone is welcome to attend, if they would like to discuss a topic or just listen in.
Mamba: The Fast Cross-Platform Package Manager
mamba
mambais a reimplementation of the conda package manager in C++.mambaare implemented in C++ for maximum efficiencyAt the same time,
mambautilizes the same command line parser, package installation and deinstallation code and transaction verification routines ascondato stay as compatible as possible.mambais part of the conda-forge ecosystem, which also consists ofquetz, an open sourcecondapackage server.You can read our announcement blog post.
micromamba
micromambais the statically linked version ofmamba.It can be installed as a standalone executable without any dependencies, making it a perfect fit for CI/CD pipelines and containerized environments.
See the documentation on
micromambafor details.mambav.s.micromambamambahas to be preferred when:libmambapyorlibmambais used by other software in the same environment.micromambahas to be preferred when:Installation
Please refer to the mamba and micromamba installation guide in the documentation.
Additional features in Mamba and Micromamba
mambaandmicromambacome with features on top of stockconda.repoqueryTo efficiently query repositories and query package dependencies you can use
mamba repoqueryormicromamba repoquery.See the repoquery documentation for details.
Installing lock files
micromambacan be used to install lock files generated by conda-lock without having to installconda-lock.Simply invoke
micromamba createwith the-foption, providing an environment lockfile whose name ends with-lock.ymlor-lock.yaml; for instance:setup-micromamba (setup-miniconda replacement)
setup-micromamba is a replacement for setup-miniconda that uses
micromamba.It can significantly reduce your CI setup time by:
micromamba, which takes around 1 s to install.condaenvironments.Differences with
condaWhile
mambaandmicromambaare generally a drop-in replacement forcondathere are some differences:mambaandmicromambanormalizeMatchSpecstrings to the simplest form, whereascondause a more verbose form This can lead to slight differences in the output ofconda env exportandmamba env export.Development installation
Please refer to the instructions given by the official documentation.
API and ABI stability
The Mamba project uses semantic versioning of the form
MAJOR.MINOR.PATCH. While we try to keep things stable for users, we also need to make breaking changes to improve Mamba and reduce technical debt. Future versions of Mamba may give stronger guarantees.libmamba(C++)We are not aware of consumers of the C++ API, so we give ourselves room for improvements. For
libmamba, the term backward compatible is understood as follows:detailsub-namespaces. The observed behavior will be the same, except for bugs (disappearing, hopefully) and performance. When declarations are deprecated but not removed and still functional, we consider it also backward compatible, as only the observed behavior during compilation changes.With this in mind,
libmambaoffers the following guarantees:PATCHreleases are API and ABI backward compatible;MINORreleases are API compatible for declarations inmamba/api, They can break API elsewhere and ABI anywhere;MAJORreleases make no guarantees.libmambapy(Python)For
libmambapy, the term API backward compatible implies that your Python code will work the same for a newer version oflibmambapyas long as you did not use any declaration understood to be private, for instance accessed with a name starting with an_. The observed behavior will be the same, except for bugs (disappearing, hopefully) and performance. When declarations are deprecated but not removed and still functional, we consider it also backward compatible, as the behavior is only observable when activating PythonDeprecationWarning, which is usually only activated in development.With this in mind,
libmambapyoffers the following guarantees:PATCHreleases are API backward compatible;MINORreleases are API backward compatible;MAJORreleases make no guarantees.mambaandmicromamba(executables)For executables, the term backward compatible applies to programmable inputs and outputs and means that your code (including shell scripts) will work with newer versions of the executable without modifications. Programmable inputs/outputs include executable name, command line arguments, configuration files, environment variables, JSON command line outputs, and files created. It excludes human-readable output and error messages, and thus deprecation warnings written in the human-readable output.
With this in mind,
mambaandmicromambaoffer the following guarantees:PATCHreleases are backward compatible;MINORreleases are backward compatible;MAJORreleases make no guarantees.Support us
Only
mambaandmicromamba2.0 and later are supported and are actively developed.The
1.xbranch is only maintained for addressing security issues such as CVEs.For questions, you can also join us on the QuantStack Chat or on the Conda channel (note that this project is not officially affiliated with
condaor Anaconda Inc.).License
We use a shared copyright model that enables all contributors to maintain the copyright on their contributions.
This software is licensed under the BSD-3-Clause license. See the LICENSE file for details.
Biweekly Dev Meeting
We have videoconference meetings every two weeks where we discuss what we have been working on and get feedback from one another.
Anyone is welcome to attend, if they would like to discuss a topic or just listen in.