- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 MQTT 设置 ActiveMQ 代理,该代理使用外部服务进行用户身份验证。
我弄清楚了如何编写 BrokerFilter 并将其插入代理,因此基础知识已涵盖。
我什至可以使用 addConsumer()
覆盖来限制用户可以订阅的主题。该方法如下所示,并且有效:
override fun addConsumer(context: ConnectionContext?, info: ConsumerInfo?): Subscription {
// let connections from the local vm through
return if (isLocalConnection(context!!)) {
super.addConsumer(context, info)
} else {
val username = context?.userName ?: ""
val cameraCode = getTopicElementsFromDestination(info!!.destination).first()
assertUserHasPermissionForCamera(username, cameraCode)
super.addConsumer(context, info)
}
}
因此,我认为限制发布与重写 addProducer()
的效果几乎相同,但我偶然发现了一些问题。
第一个问题是订阅也调用了 addProducer()
,这至少可以说是令人惊讶的。但真正令人惊讶的是,调用此方法时 ConsumerInfo::destination
始终为 null。我进行了广泛的搜索,但无法找到一种方法来从传递给 addProducer()
的信息中提取要发布的主题。在不知道制作者要发布到哪个主题的情况下,我显然无法限制它。
所以我尝试重写 messageDelivered()
,认为当消息发布到错误的主题时我可以丢弃该消息,从而达到或多或少相同的效果。根据文档,只要代理收到消息,就应该调用此方法。但是当我向经纪人发送消息时它不会被调用,所以要么我误解了“消息传递给经纪人”的含义,要么有些可疑。我还尝试了 addSession()
,它也没有被调用。
那么...当客户端发布到某个主题时如何拦截?
最佳答案
在浏览了源代码和许多重写方法并查看它们何时被调用以及它们收到什么之后,我学到了两件事帮助我做我想做的事情:
要发布的主题封装在消息中。 Producer 并不注册发布到某个主题,它只是注册发布到任何主题。代理本身不知道哪个主题是逐条消息处理的。因此,我第一次尝试限制 addProducer() 中的主题是徒劳的,因为没有人知道该主题。
发布链中用户名和主题均可用的最早点是 addDestination()。主题首先可以在 send() 中获知,但你没有用户。可以通过保留上下文的用户名来进行授权,但我不喜欢状态。所以我将授权放入 addDestination() 中,并且它起作用了。
不过,这里有一个潜在的警告。根据文档,仅当目的地尚不存在时才会调用 addDestination() 。我在有限的时间内所做的所有测试都证实,即使有人订阅了该主题,发布时也总是出现这种情况。但如果生产者维护持久连接,情况可能会有所不同,因此请谨慎使用此解决方案。
关于java - ActiveMQ:拦截发布到某个主题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49671798/
场景: private readonly IConnection connection; this.connection = connectionFactory.CreateConnection();
想知道是否可以在 activeMQ 服务器中完成任何配置,将消息从 DLQ 重定向到同一服务器上的另一个队列。 例如。 我有一个队列“MAINQUEUE”,其中有很多消息已激活客户端确认,在处理时如果
我正在 ActiveMQ 中的一个系统上工作,我真的不想丢失消息。我的问题是重试消息导致我的消费者阻塞(而不是处理他们可以处理的消息)。我想给失败的消息几天重试(例如,我的潜在目的地之一是我将通过 S
我们对 AMQ 使用以下配置 定期我有奇怪的问题 - 松散的消息。实际上AMQ说一切正常并且消
我已按照教程安装 ActiveMQ http://servicebus.blogspot.com/2011/02/installing-apache-active-mq-on-ubuntu.html
当我们使用 ActiveMQ 时,我们可以信任 ActiveMQ 服务器的可靠性。例如在开发非实时软件时(不需要立即发送数据。但应该发送)。我们能否信任 activeMQ 作为确认消息传递的可靠来源。
我遇到了 issue使用 ActiveMQ 并希望跟踪/查看所有 ActiveMQ 事件。我能找到的唯一日志文件是与持久数据相关联的(如果打开的话)。我是否查看或生成了任何其他日志文件来告诉我 Act
我们正面临 ActiveMQ 及其使用者的随机问题。我们观察到,即使连接到 ActiveMQ 队列,也很少有消费者没有收到消息。但是在消费者重启后它工作正常。 我们在 ActiveMQ 端有一个名为
有什么方法可以跟踪 ActiveMQ 中的延迟(计划)消息? 我在 AMQ 网络控制台中没有看到任何东西,它们似乎只有在延迟到期时才进入队列……而且我在 JMX 控制台中也找不到它,也许我搜索得不够好
我对Apache ActiveMQ的功能感到困惑。 我从this link下载了ActiveMQ 。所以我这样使用它(环境:Windows 7):我启动 bin/activemq.bat,然后它就可以
我们有一个 ActiveMQ 代理,它使用 JMS、AMQP 和 MQTT 连接到不同的客户端。由于某种原因,我们还没有弄清楚一组特定的 MQTT 客户端经常(并非总是)持久订阅。这是一个测试环境,其
在activemq中有什么方法可以获取消息的数量代理端每秒/每分钟消耗/产生的数量? 我已经尝试使用http://activemq.apache.org/jmeter-performance-test
如何在队列上的 ActiveMQ 中设置 redeliveryPolicy? 1) 在文档中,请参阅:activeMQ Redelivery ,说明您应该在 ConnectionFactory 或 C
我查了一下,它用于在两个系统之间发送消息。 但为什么?为什么不直接使用数据库? 一定有一些 ActiveMQ 具有 数据库 没有的功能吗? 最佳答案 它用于在两个分布式进程之间进行可靠的通信。 是的,
我在生产系统中运行 ActiveMQ。我们的一些队列的流量非常大,而有些队列的流量非常低。我对镜像其中一个低容量队列感兴趣,这样我就可以围绕接收到的消息构建非正式的监控服务。 不幸的是,the onl
我们已经使用此配置为 ActiveMQ Broker 配置了 Broker redelivery 插件。
有什么方法可以检查特定队列是否已存在于 ActiveMQ 中? 最佳答案 http://activemq.apache.org/how-can-i-get-a-list-of-the-topics-a
有人知道如何将 activemq-core.xsd url 与 jar 文件 (activemq-core-5.2.0.jar) 中的 activemq.xsd 关联起来? 我在互联网上找到了一些解决
我是 activemq 的新手。我试图使用 activemq 代理来订阅/发布消息。但至于缺乏经验,我不知道该怎么做,也不知道是否真的可以做到。我在谷歌上搜索了很多,但不幸的是,没有适合此类功能的示例
我一直在努力配置 ActiveMQ 代理,让我感到困惑的一件事是,我读过的所有内容都将 NIO 描述为“如果您需要扩展的不错选择”或“如果您需要更快的速度” ,所以我的问题是他们为什么不说“总是使用
我是一名优秀的程序员,十分优秀!