rabbitmq يعطي "رفض الوصول، ورفض تسجيل الدخول للمستخدم" عند محاولة اتباع دروس الكرفس
سؤال
أحاول اتباع تعليمي الكرفس, ، لكنني أركض مشكلة عندما أركض python manage.py celeryd
: لن يسمح خادم RabBitMQ (المثبت على جهاز ظاهري في صندوق Dev) تسجيل دخول المستخدم الخاص بي.
احصل على ما يلي على وحدة التحكم في إدارة DJANGO الخاصة بي:
[ERROR/MainProcess] AMQP Listener: Connection Error: Socket closed. Trying again in 2 seconds...
وهذا يظهر في بلدي rabbit.log
ملف على خادم الأرانب الخاص بي:
exception on TCP connection <0.5814.0> from $DJANGO_BOX_IP
{channel0_error,starting,{amqp,access_refused,"login refused for user '$CONFIGURED_USER'",'connection.start_ok'}}
لقد قمت بفحص المستخدمين، والأذونات ومعلومات Vhost، ويبدو أنهم جميعا يتنافسون. أي مساعدة استكشاف الأخطاء وإصلاحها موضع تقدير كبير.
تحديث: بعد نصيحة asksol أحصل على Traceback التالية:
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/carrot/connection.pyc in connection(self)
118 return
119 if not self._connection:
--> 120 self._connection = self._establish_connection()
121 self._closed = False
122 return self._connection
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/carrot/connection.pyc in _establish_connection(self)
131
132 def _establish_connection(self):
--> 133 return self.create_backend().establish_connection()
134
135 def get_backend_cls(self):
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/carrot/backends/pyamqplib.pyc in establish_connection(self)
110 insist=conninfo.insist,
111 ssl=conninfo.ssl,
--> 112 connect_timeout=conninfo.connect_timeout)
113
114 def close_connection(self, connection):
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/amqplib/client_0_8/connection.pyc in __init__(self, host, userid, password, login_method, login_response, virtual_host, locale, client_properties, ssl, insist, connect_timeout, **kwargs)
138 self.wait(allowed_methods=[
139 (10, 20), # secure
--> 140 (10, 30), # tune
141 ])
142
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/amqplib/client_0_8/abstract_channel.pyc in wait(self, allowed_methods)
88 method_sig, args, content = self.connection._wait_method(
---> 89 self.channel_id, allowed_methods)
90
91 if content \
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/amqplib/client_0_8/connection.pyc in _wait_method(self, channel_id, allowed_methods)
196 while True:
197 channel, method_sig, args, content = \
--> 198 self.method_reader.read_method()
199
200 if (channel == channel_id) \
$MY_VIRTUAL_ENV/lib/python2.6/site-packages/amqplib/client_0_8/method_framing.pyc in read_method(self)
213 m = self.queue.get()
214 if isinstance(m, Exception):
--> 215 raise m
216 return m
217
IOError: Socket closed
المحلول
هل تقوم بتشغيل django؟ إذا كان الأمر كذلك، فجرب هذا:
>>> from carrot.connection import DjangoBrokerConnection
>>> c = DjangoBrokerConnection()
>>> c.connection
هل يعطي نفس الشيء؟ هل أنت متأكد من أنك توصل إلى اسم المضيف المناسب، وأن اسم المستخدم وكلمة المرور لديه حق الوصول إلى المضيف الافتراضي؟
تحديث:
>>> from carrot.connection import DjangoBrokerConnection
>>> c = DjangoBrokerConnection()
>>> for n in ("host", "userid", "password", "virtual_host", "ssl"):
... print("%s -> %s" % (n, repr(getattr(c, n, None))))
تحديث: عليك أن تفعل ما سبق قبل تشغيل C.Connection، حيث يتم إنشاء الاتصال بضغط في الجزر.