带有Docker和Oracle CQN的动态端口

时间:2018-08-08 15:24:59

标签: node.js docker oracle11g socket.io

我有一个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 个答案:

答案 0 :(得分:1)

它在Docker之外有效,因为与主机映像相比,主机的端口(“范围广泛”)更加自由。

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

对容器执行此操作的一种方法是使用# https://stackoverflow.com/a/51640641/ @Divakar def skipped_view(a, m, n): s = a.strides[0] strided = np.lib.stride_tricks.as_strided shp = ((a.size+n-1)//n,n) return strided(a,shape=shp,strides=(n*s,s), writeable=False)[:,:m] out = skipped_view(arr,chunk,chunk+sep) ,它直接将主机的网络呈现给容器。您不需要In [255]: arr Out[255]: array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]) In [256]: chunk = 3 In [257]: sep = 2 In [258]: skipped_view(arr,chunk,chunk+sep) Out[258]: array([[ 0, 1, 2], [ 5, 6, 7], [10, 11, 12]]) # Let's prove that the output is a view indeed In [259]: np.shares_memory(arr, skipped_view(arr,chunk,chunk+sep)) Out[259]: True 端口,然后容器即可使用Oracle服务定义的端口。