首页 文章

具有Docker和Oracle CQN的动态端口

提问于
浏览
0

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

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

SELECT REGID, REGFLAGS, CALLBACK FROM USER_CHANGE_NOTIFICATION_REGS;

enter image description here

注册订阅时,会为其分配一个随机可用的端口,在本例中为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之外很好用,这真的令人沮丧 .

1 回答

  • 1

    它在Docker之外工作,因为你对主机的端口(“范围广泛”)比对容器图像更加自由 .

    如果您愿意让您的主机显示端口范围,那么允许在该主机上运行的容器接受相同的范围几乎没有什么区别 .

    实现此容器的一种方法是 --net=host ,它直接显示主机's networking to the container' . 您不需要 --publish 端口,然后容器可以使用Oracle服务定义的端口 .

相关问题