installing python packages without internet and using source code as .tar.gz and .whl

150,932

Solution 1

This is how I handle this case:

On the machine where I have access to Internet:

mkdir keystone-deps
pip download python-keystoneclient -d "/home/aviuser/keystone-deps"
tar cvfz keystone-deps.tgz keystone-deps

Then move the tar file to the destination machine that does not have Internet access and perform the following:

tar xvfz keystone-deps.tgz
cd keystone-deps
pip install python_keystoneclient-2.3.1-py2.py3-none-any.whl -f ./ --no-index

You may need to add --no-deps to the command as follows:

pip install python_keystoneclient-2.3.1-py2.py3-none-any.whl -f ./ --no-index --no-deps

Solution 2

If you want to install a bunch of dependencies from, say a requirements.txt, you would do:

mkdir dependencies
pip download -r requirements.txt -d "./dependencies"
tar cvfz dependencies.tar.gz dependencies

And, once you transfer the dependencies.tar.gz to the machine which does not have internet you would do:

tar zxvf dependencies.tar.gz
cd dependencies
pip install * -f ./ --no-index

Solution 3

We have a similar situation at work, where the production machines have no access to the Internet; therefore everything has to be managed offline and off-host.

Here is what I tried with varied amounts of success:

  1. basket which is a small utility that you run on your internet-connected host. Instead of trying to install a package, it will instead download it, and everything else it requires to be installed into a directory. You then move this directory onto your target machine. Pros: very easy and simple to use, no server headaches; no ports to configure. Cons: there aren't any real showstoppers, but the biggest one is that it doesn't respect any version pinning you may have; it will always download the latest version of a package.

  2. Run a local pypi server. Used pypiserver and devpi. pypiserver is super simple to install and setup; devpi takes a bit more finagling. They both do the same thing - act as a proxy/cache for the real pypi and as a local pypi server for any home-grown packages. localshop is a new one that wasn't around when I was looking, it also has the same idea. So how it works is your internet-restricted machine will connect to these servers, they are then connected to the Internet so that they can cache and proxy the actual repository.

The problem with the second approach is that although you get maximum compatibility and access to the entire repository of Python packages, you still need to make sure any/all dependencies are installed on your target machines (for example, any headers for database drivers and a build toolchain). Further, these solutions do not cater for non-pypi repositories (for example, packages that are hosted on github).

We got very far with the second option though, so I would definitely recommend it.

Eventually, getting tired of having to deal with compatibility issues and libraries, we migrated the entire circus of servers to commercially supported docker containers.

This means that we ship everything pre-configured, nothing actually needs to be installed on the production machines and it has been the most headache-free solution for us.

We replaced the pypi repositories with a local docker image server.

Share:
150,932
srinath
Author by

srinath

Updated on July 15, 2022

Comments

  • srinath
    srinath almost 2 years

    we are trying to install couple of python packages without internet.

    For ex : python-keystoneclient
    

    For that we have the packages downloaded from https://pypi.python.org/pypi/python-keystoneclient/1.7.1 and kept it in server.

    However, while installing tar.gz and .whl packages , the installation is looking for dependent packages to be installed first. Since there is no internet connection in the server, it is getting failed.

    For ex : For python-keystoneclient we have the following dependent packages

    stevedore (>=1.5.0)
    six (>=1.9.0)
    requests (>=2.5.2)
    PrettyTable (<0.8,>=0.7)
    oslo.utils (>=2.0.0)
    oslo.serialization (>=1.4.0)
    oslo.i18n (>=1.5.0)
    oslo.config (>=2.3.0)
    netaddr (!=0.7.16,>=0.7.12)
    debtcollector (>=0.3.0)
    iso8601 (>=0.1.9)
    Babel (>=1.3)
    argparse
    pbr (<2.0,>=1.6)
    

    When i try to install packages one by one from the above list, once again its looking for nested dependency .

    Is there any way we could list ALL the dependent packages for installing a python module like python-keystoneclient.

  • fffred
    fffred over 7 years
    This could be updated with the "download" option of pip. Additionally, it would be nice to have an explanation of the pip option "no-index".
  • Praveen Yalagandula
    Praveen Yalagandula over 6 years
    You can always get a light weight pip from here: bootstrap.pypa.io/get-pip.py
  • Ben Mosher
    Ben Mosher about 6 years
    @GianlucaD'Ardia -- I downloaded a pip wheel as well and you can install it using itself with the following (trippy) command: python ~/eggs/pip-9.0.1-py2.py3-none-any.whl/pip install --no-index ~/eggs/pip-9.0.1-py2.py3-none-any.whl (replace the version particulars with your wheel's specifics)
  • Chetan.B
    Chetan.B about 6 years
    Can you share the same for windows machine
  • WesternGun
    WesternGun almost 6 years
    To add some details: pip install --help indicates that: (1)-f or --find-links means ...If a local path or file:// url that's a directory, then look for archives in the directory listing., so here it locates the files in this dir; (2)--no-index means Ignore package index (only looking at --find-links URLs instead). So pip install xxx.whl -f ./ --no-index means: find install files in the current dir instead of searching in remote repo.
  • Georgi Stoyanov
    Georgi Stoyanov over 5 years
    this method worked for me, I just think you don't need really the quotation marks on the second line.
  • deed02392
    deed02392 about 5 years
    What if my local machine uses a different platform?
  • Amit Naidu
    Amit Naidu over 4 years
    To avoid platform issues, you can try to use universal wheels if possible (none-any wheels). But if you must target a specific platform, see the --platform option of pip. @deed02392
  • Dominik Novotný
    Dominik Novotný over 3 years
    Is there an equivalent for * on Windows? I get an error saying: ERROR: Invalid requirement: '*' when on Windows station.
  • MadHatter
    MadHatter over 3 years
    Windows does not have tar, but you can make a zip folder. If not from the command line, you can use the typical right click menu to make a zip.
  • Dmitry
    Dmitry about 3 years
    @DominikNovotný there is another answer for this: for %x in (dir *.whl) do python -m pip install %x from stackoverflow.com/a/43314623/8537739. Aso notice, that installation goes alphabetically, and some libraries that depend from not yet installed will fail. So this solution could be improved. Or you need call this command untill all libraries will be installed.