我有一个Dockerized节点应用程序,该应用程序在另一台计算机上的Oracle 11g数据库中创建CQN订阅。它为Oracle提供了一个回调,并监听了3033端口...一切都很好。
我在数据库上看到我的订阅:
SELECT REGID, REGFLAGS, CALLBACK FROM USER_CHANGE_NOTIFICATION_REGS;
注册订阅后,将为其分配一个随机可用的端口,在本例中为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 :(得分: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服务定义的端口。