ORACLE CQN,具有Docker和Oracle CQN的动态端口

我有一个Dockerized节点应用程序,它在另一台机器上的Oracle 11g数据库中创建CQN订阅 . 它给Oracle一个回调并监听端口3033 ...一切都很好 .

我在数据库上看到了我的订阅:

SELECT REGID, REGFLAGS, CALLBACK FROM USER_CHANGE_NOTIFICATION_REGS;

5c923b6c-bcb4-4226-bc17-849dbd7ede9f.png

注册订阅时,会为其分配一个随机可用的端口,在本例中为18837.不幸的是,我的Docker容器没有监听18837,因此Oracle无法访问我的容器 . 没问题我只需手动指定使用哪个端口并告诉Docker在端口12345上启动 .

await conn.subscribe('mysub', {

callback: myCallback,

sql: "SELECT * FROM kpi_measurement", // the table to watch

timeout: 0

port: 12345

});

不幸 . 这是遇到“ORA-24911:无法在指定端口启动侦听器线程” . 我甚至尝试过指定我之前使用的端口,如18837.我使用炸弹的任何端口 . 此外,我不确定我是否要在数据库端启动硬编码端口,因为我不保证它们将在 生产环境 中可用 .

我想一个解决方案是将我的Docker容器暴露给一系列端口,但我已经看到这个东西选择范围很广 .

另一个解决方案是将我的容器分成两部分:1)CQN订阅注册部分和2)运行SELECT以获取动态端口的帮助程序,然后使用该动态端口启动docker回调代码 . 考虑到这种方法在Docker之外很好用,这真的令人沮丧 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值