1

我的一位同事在从 Java 创建 Oracle 队列的(非持久)订阅者时遇到问题。

队列由一个模式拥有(比如 OWNER);他正试图以另一个用户(比如订阅者)的身份连接。SUBSCRIBER 已被 OWNER 授予 DEQUEUE 特权(以及 ENQUEUE,就其价值而言)。

当他创建队列并将“multiple_consumers”选项设置为 FALSE 时,一切正常。当“multiple_consumers”设置为 TRUE(我们需要的设置)时,它会失败并显示以下内容:

oracle.jms.AQjmsException: ORA-01031: insufficient privileges
ORA-06512: at "SYS.DBMS_AQADM_SYS", line 5757
ORA-06512: at line 1
ORA-06512: at "SYS.DBMS_AQJMS", line 129
ORA-06512: at line 1
    at oracle.jms.AQjmsSession.addDurableSubscriber(AQjmsSession.java:3708)
    at oracle.jms.AQjmsSession.createSubInOldMode(AQjmsSession.java:2742)
    at oracle.jms.AQjmsSession.createDurableSubscriber(AQjmsSession.java:2400)
    at oracle.jms.AQjmsSession.forceCreateOldSubscriber(AQjmsSession.java:2884)
    at oracle.jms.AQjmsSession.createConsumer(AQjmsSession.java:6820)

如果他以 OWNER 身份连接,则成功。

如何确定需要授予 SUBSCRIBER 哪些权限?

4

1 回答 1

2

您要么必须创建一个持久订阅者,要么将 AQ_ADMINISTRATOR_ROLE 授予连接用户 - 这不是一个很好的安全模型,但这是 Oracle 暂时的实现。

https://forums.oracle.com/forums/thread.jspa?messageID=9793091

于 2009-05-15T19:27:41.690 回答