What is pip's `--no-cache-dir` good for?
- Cached is: store away in hiding or for future use
- Used for
- store the installation files(
.whl
, etc) of the modules that you install through pip - store the source files (
.tar.gz
, etc) to avoid re-download when not expired
- Possible Reason you might want to disable cache:
- you don't have space on your hard drive
- previously run
pip install
with unexpected settings- eg:
- previously run
export PYCURL_SSL_LIBRARY=nss
andpip install pycurl
- want new run
export PYCURL_SSL_LIBRARY=openssl
andpip install pycurl --compile --no-cache-dir
- previously run
- eg:
- you want to keep a Docker image as small as possible
Links to documentation
https://pip.pypa.io/en/stable/reference/pip_install/#caching – @emredjan https://pip.pypa.io/en/stable/reference/pip_install/ - @mikea
I think there is a good reason to use --no-cache-dir
when you are building Docker images. The cache is usually useless in a Docker image, and you can definitely shrink the image size by disabling the cache.
Another reason to disable the pip cache - if you run pip as a user that does not yet exist, their home directory will be created, but owned by root.
This happens to us when building Amazon AMIs in a chroot - pip is being run as a user that exists on the builder machine, but not in the chroot jail where the AMI is being constructed. This is problematic as that specific user can now not ssh to what was just built as their .ssh directory is not readable by them.
I can't think of any other reason pip would be run as a user that doesn't exist though, so it's very much an edge case.