0

我对 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

在前端,我没有收到消息或错误。

4

1 回答 1

1

您还需要在 STOMPCONNECT框架中传递主机信息。

这就是规范所说的内容,客户必须设置此标头

host :客户端希望连接的虚拟主机的名称。建议客户端将此设置为建立套接字的主机名,或他们选择的任何名称。如果此标头与已知虚拟主机不匹配,支持虚拟主机的服务器可以选择默认虚拟主机或拒绝连接。

这就是您的 CONNET 框架的外观

CONNECT
login:frontend_listener
passcode:xxx
accept-version:1.0,1.1,1.2
host: someVhost
heart-beat:20000,0
于 2020-02-12T15:09:03.770 回答