Install Python packages with pip to either the system or a virtualenv
New in version 2014.7.4.
Salt now uses a portable python. As a result the entire pip module is now functional on the salt installation itself. You can pip install dependencies for your custom modules. You can even upgrade salt itself using pip. For this to work properly, you must specify the Current Working Directory (cwd
) and the Pip Binary (bin_env
) salt should use. The variable pip_bin
can be either a virtualenv path or the path to the pip binary itself.
For example, the following command will list all software installed using pip to your current salt environment:
salt <minion> pip.list cwd='C:\salt\bin\Scripts' bin_env='C:\salt\bin\Scripts\pip.exe'
Specifying the cwd
and bin_env
options ensures you're modifying the salt environment. If these are omitted, it will default to the local installation of python. If python is not installed locally it will fail saying it couldn't find pip.
This functionality works in states as well. If you need to pip install colorama with a state, for example, the following will work:
install_colorama: pip.installed: - name: colorama - cwd: 'C:\salt\bin\scripts' - bin_env: 'C:\salt\bin\scripts\pip.exe' - upgrade: True
You can now update salt using pip to any version from the 2014.7 branch forward. Previous version require recompiling some of the dependencies which is painful in windows.
To do this you just use pip with git to update to the version you want and then restart the service. Here is a sample state file that upgrades salt to the head of the 2015.5 branch:
install_salt: pip.installed: - cwd: 'C:\salt\bin\scripts' - bin_env: 'C:\salt\bin\scripts\pip.exe' - editable: git+https://github.com/saltstack/[email protected]#egg=salt - upgrade: True restart_service: service.running: - name: salt-minion - enable: True - watch: - pip: install_salt
Note
If you're having problems, you might try doubling the back slashes. For example, cwd: 'C:\salt\bin\scripts'. Sometimes python thinks the single back slash is an escape character.
Return a list of installed packages either globally or in the specified virtualenv
/usr/bin/pip-2.7
or /usr/bin/pip-2.6
. If a directory path is specified, it is assumed to be a virtualenv.Note
If the version of pip available is older than 8.0.3, the list will not include the packages pip
, wheel
, setuptools
, or distribute
even if they are installed.
CLI Example:
salt '*' pip.freeze bin_env=/home/code/path/to/virtualenv
Install packages with pip
Install packages individually or from a pip requirements file. Install packages globally or to a virtualenv.
Path to pip (or to a virtualenv). This can be used to specify the path to the pip to use when more than one Python release is installed (e.g. /usr/bin/pip-2.7
or /usr/bin/pip-2.6
. If a directory path is specified, it is assumed to be a virtualenv.
Note
For Windows, if the pip module is being used to upgrade the pip package, bin_env should be the path to the virtualenv or to the python binary that should be used. The pip command is unable to upgrade itself in Windows.
user:[email protected]:port
. Note that the user:password@
is optional and required only if you are behind an authenticated proxy. If you provide [email protected]:port
then you will be prompted for a password.git+https://github.com/worldcompany/djangoembed.git#egg=djangoembed
)index_url
Specific mirror URL(s) to query (automatically adds --use-mirrors)
Warning
This option has been deprecated and removed in pip version 7.0.0. Please use index_url
and/or extra_index_url
instead.
build
dirtarget
dirdownload
instead of installing themdownload_cache
or cache_dir
direditable
packages into source
dir--no-install
)--install-option='--install-scripts=/usr/local/bin'
). Use multiple --install-option options to pass multiple options to setup.py install. If you are using an option with a directory path, be sure to use absolute path.Set environment variables that some builds will depend on. For example, a Python C-module may have a Makefile that needs INCLUDE_PATH set to pick up a header file while compiling. This must be in the form of a dictionary or a mapping.
Example:
salt '*' pip.install django_app env_vars="{'CUSTOM_PATH': '/opt/django_app'}"
CLI Example:
salt '*' pip.install <package name>,<package2 name> salt '*' pip.install requirements=/path/to/requirements.txt salt '*' pip.install <package name> bin_env=/path/to/virtualenv salt '*' pip.install <package name> bin_env=/path/to/pip_bin
Complicated CLI example:
salt '*' pip.install markdown,django editable=git+https://github.com/worldcompany/djangoembed.git#egg=djangoembed upgrade=True no_deps=True
New in version 2018.3.0.
Filter list of installed apps from freeze
and return True or False if pkgname
exists in the list of packages installed.
Note
If the version of pip available is older than 8.0.3, the packages wheel, setuptools, and distribute will not be reported by this function even if they are installed. Unlike pip.freeze
, this function always reports the version of pip which is installed.
CLI Example:
salt '*' pip.is_installed salt
Filter list of installed apps from freeze
and check to see if prefix
exists in the list of packages installed.
Note
If the version of pip available is older than 8.0.3, the packages wheel
, setuptools
, and distribute
will not be reported by this function even if they are installed. Unlike pip.freeze
, this function always reports the version of pip which is installed.
CLI Example:
salt '*' pip.list salt
New in version 2017.7.3.
List all available versions of a pip package
/usr/bin/pip-2.7
or /usr/bin/pip-2.6
. If a directory path is specified, it is assumed to be a virtualenv.CLI Example:
salt '*' pip.list_all_versions <package name>
Check whether or not an upgrade is available for all packages
CLI Example:
salt '*' pip.list_upgrades
Uninstall packages individually or from a pip requirements file
/usr/bin/pip-2.7
or /usr/bin/pip-2.6
. If a directory path is specified, it is assumed to be a virtualenv.user:[email protected]:port
. Note that the user:password@
is optional and required only if you are behind an authenticated proxy. If you provide [email protected]:port
then you will be prompted for a password.CLI Example:
salt '*' pip.uninstall <package name>,<package2 name> salt '*' pip.uninstall requirements=/path/to/requirements.txt salt '*' pip.uninstall <package name> bin_env=/path/to/virtualenv salt '*' pip.uninstall <package name> bin_env=/path/to/pip_bin
New in version 2015.5.0.
Upgrades outdated pip packages.
Note
On Windows you can't update salt from pip using salt, so salt will be skipped
Returns a dict containing the changes.
- {'<package>': {'old': '<old-version>',
- 'new': '<new-version>'}}
CLI Example:
salt '*' pip.upgrade
New in version 2015.5.0.
Check whether or not an upgrade is available for a given package
CLI Example:
salt '*' pip.upgrade_available <package name>
New in version 0.17.0.
Returns the version of pip. Use bin_env
to specify the path to a virtualenv and get the version of pip in that virtualenv.
If unable to detect the pip version, returns None
.
CLI Example:
salt '*' pip.version
© 2019 SaltStack.
Licensed under the Apache License, Version 2.0.
https://docs.saltstack.com/en/latest/ref/modules/all/salt.modules.pip.html