На нашей установке Openstack что-то ужасно пошло не так. Теперь python больше не работает как надо. Путь к модулю не найден:
root@controller:/root# keystone token-get
Traceback (most recent call last):
File "/usr/bin/keystone", line 6, in <module>
from keystoneclient.shell import main
ImportError: No module named shell
Если я добавляю путь к модулю через переменную среды, эта ошибка исчезает... (другая ошибка в данный момент не имеет значения)
root@controller:/root# export PYTHONPATH=/usr/lib/python2.7/dist-packages
root@controller:/root# keystone token-get
Authorization Failed: Unable to establish connection to http://controller:35357/v2.0/tokens
Странная деталь: даже без установки переменной окружения python -m site, похоже, знает правильный путь:
sys.path = [
'/root',
'/usr/lib/python2.7',
'/usr/lib/python2.7/plat-x86_64-linux-gnu',
'/usr/lib/python2.7/lib-tk',
'/usr/lib/python2.7/lib-old',
'/usr/lib/python2.7/lib-dynload',
'/usr/local/lib/python2.7/dist-packages',
'/usr/lib/python2.7/dist-packages',
'/usr/lib/python2.7/dist-packages/gtk-2.0',
]
USER_BASE: '/root/.local' (doesn't exist)
USER_SITE: '/root/.local/lib/python2.7/site-packages' (doesn't exist)
ENABLE_USER_SITE: True
Поскольку python также не работает в Apache для панели мониторинга, не вариант каждый раз устанавливать переменную окружения с "export". Нам нужно исправить проблему в другом месте.
Где настроен путь включения Python?
ОБНОВЛЯТЬ:
Порядок путей к библиотекам, похоже, имеет значение. Это работает:
PYTHONPATH=/usr/lib/python2.7/dist-packages:/usr/local/lib/python2.7/dist-packages; keystone token-get
и это не работает:
PYTHONPATH=/usr/local/lib/python2.7/dist-packages:/usr/lib/python2.7/dist-packages; keystone token-get
решение1
export PYTHONPATH=/usr/lib/python2.7/dist-packages:/usr/local/lib/python2.7/dist-packages; keystone token-get
Мне помогло, спасибо