我对 RabbitMQ 完全陌生,现在我正在寻找配置错误。客户端没有收到来自 RabbitMQ 的任何消息,我尽可能地对其进行了调试。
前端消息:
消息 1:
CONNECT
login:frontend_listener
passcode:xxx
accept-version:1.0,1.1,1.2
heart-beat:20000,0
消息 2:
ERROR
message:Bad CONNECT
content-type:text/plain
version:1.0,1.1,1.2
content-length:30
Virtual host '/' access denied
有两个 vHost:/
并且someVhost
有不同的用户,例如frontend_listener
. 现在我找到了一种访问日志文件的方法。
RabbitMQ 日志文件:
2020-02-11 15:50:53.579 [warning] <0.798.0> STOMP login failed for user "frontend_listener"
2020-02-11 15:50:53.579 [error] <0.798.0> STOMP error frame sent:
Message: "Bad CONNECT"
Detail: "Access refused for user 'frontend_listener'\n"
Server private detail: none
...
2020-02-11 15:51:25.349 [info] <0.850.0> Creating user 'frontend_listener'
2020-02-11 15:51:30.374 [info] <0.857.0> Setting permissions for 'frontend_listener' in 'someVhost' to '$', '$', 'client-notification.*'
2020-02-11 15:51:54.980 [warning] <0.867.0> STOMP login failed - not_allowed (vhost access not allowed)~n
2020-02-11 15:51:54.980 [error] <0.867.0> STOMP error frame sent:
Message: "Bad CONNECT"
Detail: "Virtual host '/' access denied"
Server private detail: none
2020-02-11 15:52:56.427 [warning] <0.875.0> STOMP login failed - not_allowed (vhost access not allowed)~n
看起来权限是错误的。有人可以帮我正确解释吗?
我尝试阅读它:用户frontend_listener
想要访问 vHost ,但它没有足够的权限(除了正则表达式的一部分之外/
不知道这里是什么意思)。$
问题是,我不知道这是否是正确的 vHost。如何找出每个虚拟主机的 URL?
我问这个是因为我认为到 vHost 的映射是错误的或缺少某些东西。
编辑:
添加host: 'someVhost'
到我的之后,我stomp-config.ts
能够订阅队列。现在我在日志中收到以下错误:
2020-02-12 16:32:25.913 [error] <0.5159.1> Channel error on connection <0.5149.1> (127.0.0.1:58136 -> 127.0.0.1:15674, vhost: 'someVhost', user: 'frontend_listener'), channel 1:
operation basic.consume caused a channel exception access_refused: access to queue 'stomp-subscription-SZ3-PO1-PbZroPol-WXSQw' in vhost 'someVhost' refused for user 'frontend_listener'
2020-02-12 16:32:26.022 [error] <0.5145.1> STOMP error frame sent:
Message: access_refused
在前端,我没有收到消息或错误。