我有一个连接到 Oracle AQ 多消费者队列的客户端应用程序。我想使用 OracleAQQueue.Listen 来监听队列中的新消息。 API 文档显示 Listen 方法可用于多消费者队列。我的监听队列代码如下所示。
string consumerName = "APPINST1";
using (OracleConnection con = new OracleConnection(connectionString))
{
con.Open();
OracleAQQueue queue = new OracleAQQueue("MY_Q");
queue.MessageType = OracleAQMessageType.Udt;
queue.UdtTypeName = "MY_Q_MSG";
queue.DequeueOptions.DeliveryMode = OracleAQMessageDeliveryMode.Persistent;
queue.Connection = con;
Console.WriteLine("Listening for messages...");
queue.Listen(new string[] { consumerName });
}
我遇到的问题是在我调用 queue.Listen() 的代码行上,我得到了 Oracle 异常:
ORA-25295: Subscriber is not allowed to dequeue buffered messages
谷歌搜索有关此特定错误的建议并没有太大帮助。我已经多次将我的订阅者删除并重新添加到队列中,但均无济于事。我的猜测是在调用 Listen 之前我没有正确设置某些属性,但我无法弄清楚问题所在。
有任何想法吗?