I need to run code on my Heroku Django project that requires the Python package dm.xmlsec.binding
. This in turn, depends on having the binary apt
package libxmlsec1
installed, usually via apt-get install
.
That is how I have things running locally on an Ubuntu vagrant box.
I have two "build packs" in my application. Having multiple buildpacks is enabled by using heroku-buildpack-multi.
Since my application is a Python one, my .buildpacks
contents are therefore:
https://github.com/ddollar/heroku-buildpack-apt
https://github.com/heroku/heroku-buildpack-python
The first buildpack, which refers to heroku-buildpack-apt, requires an Aptfile
to specify apt
packages; in our case the contents of this file are:
python-setuptools
libxmlsec1
libxmlsec1-dev
swig
python-m2crypto
The second buildpack is the "Heroku buildpack for Python apps, powered by pip".
So far so good.
The problem is that, while apt
packages look like being installed successfully, when pip install
actually runs, it seems not to find the apt
packages installed.
If apt
packages are being installed correctly, why is Python not finding them in the subsequent pip install
?
This is the full git push heroku
log:
git push heroku
Fetching repository, done.
Counting objects: 12, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (8/8), done.
Writing objects: 100% (9/9), 932 bytes | 0 bytes/s, done.
Total 9 (delta 3), reused 0 (delta 0)
-----> Fetching custom git buildpack... done
-----> Multipack app detected
=====> Downloading Buildpack: https://github.com/ddollar/heroku-buildpack-apt
=====> Detected Framework: Apt
-----> Updating apt caches
Ign http://archive.ubuntu.com trusty InRelease
Ign http://archive.ubuntu.com trusty-security InRelease
Ign http://archive.ubuntu.com trusty-updates InRelease
Hit http://archive.ubuntu.com trusty Release.gpg
Get:1 http://archive.ubuntu.com trusty-security Release.gpg [933 B]
Get:2 http://archive.ubuntu.com trusty-updates Release.gpg [933 B]
Hit http://archive.ubuntu.com trusty Release
Get:3 http://archive.ubuntu.com trusty-security Release [62.0 kB]
Get:4 http://archive.ubuntu.com trusty-updates Release [62.0 kB]
Hit http://archive.ubuntu.com trusty/main amd64 Packages
Hit http://archive.ubuntu.com trusty/universe amd64 Packages
Hit http://archive.ubuntu.com trusty/main Translation-en
Hit http://archive.ubuntu.com trusty/universe Translation-en
Get:5 http://archive.ubuntu.com trusty-security/main amd64 Packages [153 kB]
Hit http://archive.ubuntu.com trusty-security/main Translation-en
Get:6 http://archive.ubuntu.com trusty-updates/main amd64 Packages [356 kB]
Hit http://archive.ubuntu.com trusty-updates/main Translation-en
Fetched 635 kB in 2s (247 kB/s)
Reading package lists...
-----> Fetching .debs for python-setuptools
Reading package lists...
Building dependency tree...
The following extra packages will be installed:
python-pkg-resources
Suggested packages:
python-distribute python-distribute-doc
The following NEW packages will be installed:
python-pkg-resources python-setuptools
0 upgraded, 2 newly installed, 0 to remove and 38 not upgraded.
Need to get 292 kB of archives.
After this operation, 1017 kB of additional disk space will be used.
Get:1 http://archive.ubuntu.com/ubuntu/ trusty/main python-pkg-resources all 3.3-1ubuntu1 [61.9 kB]
Get:2 http://archive.ubuntu.com/ubuntu/ trusty/main python-setuptools all 3.3-1ubuntu1 [230 kB]
Fetched 292 kB in 0s (408 kB/s)
Download complete and in download only mode
-----> Fetching .debs for libxmlsec1
Reading package lists...
Building dependency tree...
The following NEW packages will be installed:
libxmlsec1
0 upgraded, 1 newly installed, 0 to remove and 38 not upgraded.
Need to get 0 B/115 kB of archives.
After this operation, 436 kB of additional disk space will be used.
Download complete and in download only mode
-----> Fetching .debs for libxmlsec1-dev
Reading package lists...
Building dependency tree...
The following extra packages will be installed:
libnspr4 libnspr4-dev libnss3 libnss3-dev libnss3-nssdb libxmlsec1
libxmlsec1-gcrypt libxmlsec1-gnutls libxmlsec1-nss libxmlsec1-openssl
The following NEW packages will be installed:
libnspr4 libnspr4-dev libnss3 libnss3-dev libnss3-nssdb libxmlsec1
libxmlsec1-dev libxmlsec1-gcrypt libxmlsec1-gnutls libxmlsec1-nss
libxmlsec1-openssl
0 upgraded, 11 newly installed, 0 to remove and 38 not upgraded.
Need to get 0 B/2579 kB of archives.
After this operation, 14.1 MB of additional disk space will be used.
Download complete and in download only mode
-----> Fetching .debs for swig
Reading package lists...
Building dependency tree...
The following extra packages will be installed:
swig2.0
Suggested packages:
swig-doc swig-examples swig2.0-examples swig2.0-doc
The following NEW packages will be installed:
swig swig2.0
0 upgraded, 2 newly installed, 0 to remove and 38 not upgraded.
Need to get 0 B/881 kB of archives.
After this operation, 4412 kB of additional disk space will be used.
Download complete and in download only mode
-----> Fetching .debs for python-m2crypto
Reading package lists...
Building dependency tree...
The following NEW packages will be installed:
python-m2crypto
0 upgraded, 1 newly installed, 0 to remove and 38 not upgraded.
Need to get 0 B/156 kB of archives.
After this operation, 831 kB of additional disk space will be used.
Download complete and in download only mode
-----> Installing libnspr4-dev_2%3a4.10.7-0ubuntu0.14.04.1_amd64.deb
-----> Installing libnspr4_2%3a4.10.7-0ubuntu0.14.04.1_amd64.deb
-----> Installing libnss3-dev_2%3a3.17.1-0ubuntu0.14.04.1_amd64.deb
-----> Installing libnss3-nssdb_2%3a3.17.1-0ubuntu0.14.04.1_all.deb
-----> Installing libnss3_2%3a3.17.1-0ubuntu0.14.04.1_amd64.deb
-----> Installing libxmlsec1-dev_1.2.18-2ubuntu1_amd64.deb
-----> Installing libxmlsec1-gcrypt_1.2.18-2ubuntu1_amd64.deb
-----> Installing libxmlsec1-gnutls_1.2.18-2ubuntu1_amd64.deb
-----> Installing libxmlsec1-nss_1.2.18-2ubuntu1_amd64.deb
-----> Installing libxmlsec1-openssl_1.2.18-2ubuntu1_amd64.deb
-----> Installing libxmlsec1_1.2.18-2ubuntu1_amd64.deb
-----> Installing python-m2crypto_0.21.1-3ubuntu5_amd64.deb
-----> Installing python-pkg-resources_3.3-1ubuntu1_all.deb
-----> Installing python-setuptools_3.3-1ubuntu1_all.deb
-----> Installing swig2.0_2.0.11-1ubuntu2_amd64.deb
-----> Installing swig_2.0.11-1ubuntu2_amd64.deb
-----> Writing profile script
=====> Downloading Buildpack: https://github.com/heroku/heroku-buildpack-python
=====> Detected Framework: Python
-----> Installing dependencies with pip
Downloading/unpacking dm.xmlsec.binding==1.3.1 (from -r requirements.txt (line 1))
Running setup.py (path:/tmp/pip_build_u45022/dm.xmlsec.binding/setup.py) egg_info for package dm.xmlsec.binding
Error: cannot get XMLSec1 pre-processor and compiler flags; do you have the `libxmlsec1` development package installed?
Complete output from command python setup.py egg_info:
Error: cannot get XMLSec1 pre-processor and compiler flags; do you have the `libxmlsec1` development package installed?
----------------------------------------
Cleaning up...
Command python setup.py egg_info failed with error code 1 in /tmp/pip_build_u45022/dm.xmlsec.binding
Storing debug log for failure in /app/.pip/pip.log
! Push rejected, failed to compile Multipack app
To [email protected]:xxxxxxxxxxx.git
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to '[email protected]'
Heroku also supports traditional Python package distribution, powered by setup.py . If your Python application contains a setup.py file but excludes a requirements. txt file, python setup.py develop will be used to install your package and resolve your dependencies. This works best with setuptools.
Create necessary project files These are 1) the Procfile and 2) the `requirements. txt` file. Both of these are required by Heroku to install all app dependencies and subsequently utilize Gunicorn to fire off our app in the cloud. First create the Procfile.
Run the npm install command in your local app directory to install the dependencies that you declared in your package. json file. Start your app locally using the heroku local command, which is installed as part of the Heroku CLI. Your app should now be running on http://localhost:5000/.
txt in the root directory is one way for Heroku to recognize your Python app. The requirements. txt file lists the app dependencies together. When an app is deployed, Heroku reads this file and installs the appropriate Python dependencies using the pip install -r command.
I don't know, but maybe the answer is this:
With the amazing help of @PadraicCunningham I managed to find the solution. The problem turned out to be that heroku-buildpack-apt installs things in a newly created folder /app/.apt/ which was not in the
PYTHONPATH
.So I added the relevant folder to my PYTHONPATH on heroku as follows:
heroku config:add PYTHONPATH=/app/.apt/usr/lib/python2.7/dist-packages/
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With