2016-08-01 46 views
0

我首先在heroku網站上跟着教程。我這樣做redis不能在我的python django應用程序中工作

pip install rq 

然後在worker.py文件

import os 

    import redis 
    from rq import Worker, Queue, Connection 

    listen = ['high', 'default', 'low'] 

    redis_url = os.getenv('REDISTOGO_URL', 'redis://localhost:6379') 

    conn = redis.from_url(redis_url) 

    if __name__ == '__main__': 
     with Connection(conn): 
      worker = Worker(map(Queue, listen)) 
      worker.work() 

然後

python worker.py 

,我得到了以下錯誤

 Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 439, in connect 
     sock = self._connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 494, in _connect 
     raise err 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 482, in _connect 
     sock.connect(socket_address) 
    ConnectionRefusedError: [Errno 61] Connection refused 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 572, in execute_command 
     connection.send_command(*args) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 563, in send_command 
     self.send_packed_command(self.pack_command(*args)) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 538, in send_packed_command 
     self.connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 442, in connect 
     raise ConnectionError(self._error_message(e)) 
    redis.exceptions.ConnectionError: Error 61 connecting to localhost:6379. Connection refused. 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 439, in connect 
     sock = self._connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 494, in _connect 
     raise err 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 482, in _connect 
     sock.connect(socket_address) 
    ConnectionRefusedError: [Errno 61] Connection refused 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "worker.py", line 15, in <module> 
     worker.work() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/rq/worker.py", line 423, in work 
     self.register_birth() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/rq/worker.py", line 242, in register_birth 
     if self.connection.exists(self.key) and \ 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 855, in exists 
     return self.execute_command('EXISTS', name) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 578, in execute_command 
     connection.send_command(*args) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 563, in send_command 
     self.send_packed_command(self.pack_command(*args)) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 538, in send_packed_command 
     self.connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 442, in connect 
     raise ConnectionError(self._error_message(e)) 
    redis.exceptions.ConnectionError: Error 61 connecting to localhost:6379. Connection refused. 

然後我去了谷歌,並找到了我也包的指數其次是

>>> import redis 
>>> r = redis.StrictRedis(host='localhost', port=6379, db=0) 
>>> r.set('foo', 'bar') 

回車,得到了以下信息

 Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 439, in connect 
     sock = self._connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 494, in _connect 
     raise err 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 482, in _connect 
     sock.connect(socket_address) 
    ConnectionRefusedError: [Errno 61] Connection refused 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 572, in execute_command 
     connection.send_command(*args) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 563, in send_command 
     self.send_packed_command(self.pack_command(*args)) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 538, in send_packed_command 
     self.connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 442, in connect 
     raise ConnectionError(self._error_message(e)) 
    redis.exceptions.ConnectionError: Error 61 connecting to localhost:6379. Connection refused. 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 439, in connect 
     sock = self._connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 494, in _connect 
     raise err 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 482, in _connect 
     sock.connect(socket_address) 
    ConnectionRefusedError: [Errno 61] Connection refused 

    During handling of the above exception, another exception occurred: 

    Traceback (most recent call last): 
     File "<stdin>", line 1, in <module> 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 1072, in set 
     return self.execute_command('SET', *pieces) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/client.py", line 578, in execute_command 
     connection.send_command(*args) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 563, in send_command 
     self.send_packed_command(self.pack_command(*args)) 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 538, in send_packed_command 
     self.connect() 
     File "/Users/ray/Desktop/myheroku/practice/lib/python3.5/site-packages/redis/connection.py", line 442, in connect 
     raise ConnectionError(self._error_message(e)) 
    redis.exceptions.ConnectionError: Error 61 connecting to localhost:6379. Connection refused. 

我沒有做過或多或少的又是什麼,這些教程問。我該如何做這項工作?

回答

0

您需要運行redis服務器。在控制檯上鍵入redis-server以啓動服務器(Mac OSX)。

$redis-server 

請記住,工作人員需要代理(redis)才能與您的應用進行通信。

+0

當我這樣做時我得到這個消息bash:redis-server:command not found。我是在本地還是全球安裝它?因爲我從我的演奏中做到了這一點。並在我正在閱讀的文檔中未指定。 – losee

+0

@losee你應該在全球安裝它,redis不是一個Python軟件包或應用程序。啓動服務器的命令取決於您的操作系統。 – levi

+0

brew安裝它,命中redis服務器,它的工作。步驟1。 – losee

相關問題