スクリプトを実行すると奇妙な問題が発生します。ロードできませんpymongo
が、hashbang インタープリターを実行すると使用可能になります ( /usr/bin/env python
)。
元の呼び出しimport pymongo
はクラスの奥深くに埋もれていましたが、1 行目で呼び出しても失敗します。
どうしてこれなの?
利用可能であることを示す python コンソールからの出力を次に示しpymongo
ます。
# /usr/bin/env python
Python 2.7.4 (default, Apr 23 2013, 14:02:51)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import pymongo
>>>
スクリプトの最初の 3 行を次に示します。
# head -n 3 ./app/app.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import pymongo
ここに失敗があります:
# python ./app/app.py
Traceback (most recent call last):
File "./app/app.py", line 3, in <module>
import pymongo
ImportError: No module named pymongo
しかし、実行しても問題あり/usr/bin/env
ません...なぜですか?
# /usr/bin/env python ./app/app.py
Traceback (most recent call last):
File "./app/app.py", line 37, in <module>
db = backend.flowbackend.getBackendObject(config.db_backend, config.db_host, config.db_port, config.db_user, config.db_password, config.db_name)
File "./app/../lib/backend/flowbackend.py", line 268, in getBackendObject
return MongoBackend(host, port, user, password, databaseName)
File "./app/../lib/backend/mongobackend.py", line 13, in __init__
self.connect()
File "./app/../lib/backend/mongobackend.py", line 62, in connect
self.conn = pymongo.Connection(self.host, self.port)
File "/usr/local/lib/python2.7/site-packages/pymongo/connection.py", line 220, in __init__
max_pool_size, document_class, tz_aware, _connect, **kwargs)
File "/usr/local/lib/python2.7/site-packages/pymongo/mongo_client.py", line 336, in __init__
raise ConnectionFailure(str(e))
pymongo.errors.ConnectionFailure: could not connect to 127.0.0.1:27017: [Errno 111] Connection refused