11

サーバーでコードを実行するとこのエラーが発生し、env は debian であり、Python2.7.3

Traceback (most recent call last):
  File "fetcher.py", line 4, in <module>
    import mirad.fetcher_tasks as tasks
  File "/home/mirad/backend/mirad/fetcher_tasks.py", line 75, in <module>
    redis_keys = r.keys('*')
  File "/home/mirad/backend/venv/local/lib/python2.7/site-packages/redis/client.py", line 863, in keys
    return self.execute_command('KEYS', pattern)
  File "/home/mirad/backend/venv/local/lib/python2.7/site-packages/redis/client.py", line 534, in execute_command
    connection.send_command(*args)
  File "/home/mirad/backend/venv/local/lib/python2.7/site-packages/redis/connection.py", line 532, in send_command
    self.send_packed_command(self.pack_command(*args))
  File "/home/mirad/backend/venv/local/lib/python2.7/site-packages/redis/connection.py", line 508, in send_packed_command
    self.connect()
  File "/home/mirad/backend/venv/local/lib/python2.7/site-packages/redis/connection.py", line 412, in connect
    raise ConnectionError(self._error_message(e))
redis.exceptions.ConnectionError: Error -2 connecting to localhost:6379. Name or service not known.

実行するredis-cliと、エラーなしで正しく動作します:

$ redis-cli 
127.0.0.1:6379> 
4

2 に答える 2

14

現在の Debian 環境では識別されていないサーバーに redis を接続しようとしているようです。Traceback から、ホスト名を localhost として使用して接続しようとしていることがわかります。

r_server=redis.Redis(host="localhost",port=6379)

しかし、あなたのシステムは "localhost" を理解できません。hosts ファイルにエントリを作成してください。つまり、127.0.0.1 は localhost です。以下のコードを /etc/hosts に追加します

127.0.0.1 localhost

それ以外の場合は、以下のコマンドを使用して redis を接続します。

r_server=redis.Redis(host="127.0.0.1",port=6379) 
 
于 2014-10-27T15:36:48.690 に答える