Ich habe eine Python-Anwendung, die ich als Systemdienst ausgeführt habe. Die Anwendung läuft gut, wenn ich es manuell ausführe. Wenn ich es als Dienst ausführe, findet es kein lokales Modul, das mit pip install -e my_module
installiert wurde.Python-Import des lokalen Moduls schlägt fehl, wenn es als Systemd/Systemctl-Dienst ausgeführt wird
Der Haupt der Anwendung hat die folgenden Code:
print(sys.argv)
import pip
installed_packages = pip.get_installed_distributions()
installed_packages_list = sorted(["%s==%s" % (i.key, i.version) for i in installed_packages])
print(installed_packages_list)
print('doing tox')
import tox
print('doing my_mod')
import my_mod
print(my_mod.__file__)
from my_mod.auth.http_auth_provider import HTTPAuthProvider
Wenn ich es manuell ausführen, bekomme ich (beachten Sie, dass my-Mod ist in der zweiten Zeile sind in ‚installierten Pakete‘):
['/usr/bin/pv_api']
['aiohttp==0.19.0', 'chardet==2.3.0', 'jsonschema==2.5.1', 'pip==7.0.0', 'pluggy==0.3.1', 'pv-api==0.0.0', 'py==1.4.31', 'pycrypto==2.6.1', 'pymongo==3.1.1', 'pyyaml==3.11', 'setuptools==19.6.2', 'six==1.10.0', 'tox==2.3.1', 'virtualenv==14.0.6', 'my-mod==0.1.0', 'webauthsession==1.1.1']
doing tox
doing my_mod
/root/my_module/my_mod/__init__.py
Wenn der Dienst ausgeführt durch die Protokolle wie folgt aussehen (beachten Sie, dass my-mod nicht in der zweiten Zeile in ‚installierten Pakete‘ enthalten ist) ::
2016-02-26_00:39:01.90403 ['/usr/bin/pv_api']
2016-02-26_00:39:01.90406 ['aiohttp==0.19.0', 'chardet==2.3.0', 'jsonschema==2.5.1', 'pip==7.0.0', 'pluggy==0.3.1', 'pv-api==0.0.0', 'py==1.4.31', 'pycrypto==2.6.1', 'pymongo==3.1.1', 'pyyaml==3.11', 'setuptools==19.6.2', 'six==1.10.0', 'tox==2.3.1', 'virtualenv==14.0.6', 'webauthsession==1.1.1']
2016-02-26_00:39:01.90407 doing tox
2016-02-26_00:39:01.90407 doing my_mod
2016-02-26_00:39:01.90642 Traceback (most recent call last):
2016-02-26_00:39:01.90642 File "/usr/bin/pv_api", line 9, in <module>
2016-02-26_00:39:01.90642 load_entry_point('pv-api==0.0.0', 'console_scripts', 'pv_api')()
2016-02-26_00:39:01.90643 File "/usr/lib/python3.4/site-packages/pkg_resources/__init__.py", line 547, in load_entry_point
2016-02-26_00:39:01.90643 return get_distribution(dist).load_entry_point(group, name)
2016-02-26_00:39:01.90643 File "/usr/lib/python3.4/site-packages/pkg_resources/__init__.py", line 2719, in load_entry_point
2016-02-26_00:39:01.90643 return ep.load()
2016-02-26_00:39:01.90643 File "/usr/lib/python3.4/site-packages/pkg_resources/__init__.py", line 2379, in load
2016-02-26_00:39:01.90643 return self.resolve()
2016-02-26_00:39:01.90643 File "/usr/lib/python3.4/site-packages/pkg_resources/__init__.py", line 2385, in resolve
2016-02-26_00:39:01.90644 module = __import__(self.module_name, fromlist=['__name__'], level=0)
2016-02-26_00:39:01.90644 File "/usr/lib/python3.4/site-packages/pv/api/main.py", line 33, in <module>
2016-02-26_00:39:01.90644 import my_mod
2016-02-26_00:39:01.90644 ImportError: No module named 'my_mod'
Diese
könnten auch nützliche Informationen sein:
[[email protected] etc]# ls -la /usr/lib/python3.4/site-packages/my-mod.egg-link
-rw-r--r-- 1 root root 37 Feb 26 00:20 /usr/lib/python3.4/site-packages/my-mod.egg-link
[[email protected] etc]# cat /usr/lib/python3.4/site-packages/my-mod.egg-link
/root/my_module
Edit:
Wie Sie aus der Ausgabe von ‚installed_packages‘ sehen können, alle anderen Pakete, die über requirements.txt installiert sind richtig gefunden . Nur diese eine Bibliothek, für die ich Quellcode lokal habe, wird nicht gefunden, wenn ich als Dienst ausgeführt werde. (Es wird gefunden, wenn ich von der Kommandozeile ausgeführt werden oder wenn ich import my_mod
vom python3-Interpreter ausführen.
Dies kam ziemlich nah an das eigentliche Problem hervorzuheben. Das Problem bestand darin, dass der Dienst als Benutzer ausgeführt wurde, der keine Leseberechtigung für den Ordner hatte, von dem mein Modul installiert wurde. – user1753106