PHP скрипт не может получить вывод от Python скрипта

У меня проблема с выполнением сценария Python из сценария PHP. Мой клиент использует Bluehost, поэтому я установил сторонний модуль (numpy) для Python с помощью метода easy_install, описанного здесь: https://my.bluehost.com/cgi/help/530?step=530

Чтобы продемонстрировать свою проблему, я создал два сценария Python и сценарий PHP.

hello.py содержит:

print "Hello, World!"

hello-numpy.py содержит:

import numpy
print "Hello, World!"

PHP-скрипт содержит:

Output from exec('python hello.py'): 
Output from exec('python hello-numpy.py'):
Output from exec('whoami'):

Затем я получаю такой вывод из PHP:

Вывод exec('python hello.py'): Hello, World!
Вывод из exec('python hello-numpy.py'):
Выход exec('whoami'): venicetw

Однако запуск этих скриптов из окна SSH дает следующие результаты:

# python hello.py
Hello, World!
# python hello-numpy.py
Hello, World!
# whoami
venicetw

Похоже, что PHP не получает никакого результата, когда скрипт Python импортирует numpy, но он отлично работает из SSH. Более того, PHP получает статус возврата 0 для hello.py, но 1 для hello-numpy.py. Я подумал, что это может быть проблема с правами, но и PHP, и SSH работают от имени пользователя "venicetw". Что может помешать PHP и Apache получить вывод от сценария Python? Могу ли я обсудить это с Bluehost, или мне следует проверить что-то еще? Мы используем Apache 2.2.21, PHP 5.2.17, Python 2.4.3 и numpy 1.6.0.

Обновление: SSH печатает следующие пути Python:

/home8/venicetw/public_html/venicenoise/python
/home8/venicetw/.local/lib/python2.4/site-packages/ogcserver-0.1.0-py2.4.egg
/home8/venicetw/.local/lib/python2.4/site-packages/PIL-1.1.7-py2.4-linux-x86_64.egg
/home8/venicetw/.local/lib/python2.4/site-packages/lxml-2.3.2-py2.4-linux-x86_64.egg
/home8/venicetw/.local/lib/python2.4/site-packages/WebOb-1.2b2-py2.4.egg
/home8/venicetw/.local/lib/python2.4/site-packages/PasteScript-1.7.5-py2.4.egg
/home8/venicetw/.local/lib/python2.4/site-packages/PasteDeploy-1.5.0-py2.4.egg
/home8/venicetw/.local/lib/python2.4/site-packages/Paste-1.7.5.1-py2.4.egg
/home8/venicetw/.local/lib/python2.4/site-packages/numpy-1.6.0-py2.4-linux-x86_64.egg
/home8/venicetw/.local/lib/python2.4/site-packages
/home8/venicetw/.local/lib/python/site-packages
/home8/venicetw/public_html/venicenoise/python
/usr/lib64/python24.zip
/usr/lib64/python2.4
/usr/lib64/python2.4/plat-linux2
/usr/lib64/python2.4/lib-tk
/usr/lib64/python2.4/lib-dynload
/usr/lib64/python2.4/site-packages
/usr/lib64/python2.4/site-packages/Numeric
/usr/lib64/python2.4/site-packages/PIL
/usr/lib64/python2.4/site-packages/gtk-2.0
/usr/lib/python2.4/site-packages

Но Apache печатает только эти пути Python:

/home8/venicetw/public_html/venicenoise/python
/usr/lib64/python24.zip
/usr/lib64/python2.4
/usr/lib64/python2.4/plat-linux2
/usr/lib64/python2.4/lib-tk
/usr/lib64/python2.4/lib-dynload
/usr/lib64/python2.4/site-packages
/usr/lib64/python2.4/site-packages/Numeric
/usr/lib64/python2.4/site-packages/PIL
/usr/lib64/python2.4/site-packages/gtk-2.0
/usr/lib/python2.4/site-packages

Решение: Выполнив /usr/bin/env как из PHP, так и из SSH, я смог определить, что в PHP отсутствует переменная окружения для пути Python, где установлен numpy. В этом случае, добавив

putenv('PYTHONPATH=/home8/venicetw/.local/lib/python2.4/site-packages:/home8/venicetw/.local/lib/python/site-packages:');

в начало PHP-скрипта, все работает, как ожидалось.

6
задан 2 January 2012 в 23:22
поделиться