我使用Docker在macOS Sierra 10.12.2上运行Oracle 11g Express
https://github.com/wnameless/docker-oracle-xe-11g
这是我的错误:
Last login: Sat Jan 7 22:42:11 on ttys000
➜ ~ docker run -d -p 49160:22 -p 49161:1521 wnameless/oracle-xe-11g
docker: Cannot connect to the Docker daemon. Is the docker daemon running on this host?.
See 'docker run --help'.
➜ ~ docker run -d -p 49160:22 -p 49161:1521 wnameless/oracle-xe-11g
043d8caecbb45d6e2e5999b69a2f760c20d53ff3aa2fad78cb1eb70acb058a1f
docker: Error response from daemon: driver failed programming external connectivity on endpoint serene_lalande (08bb0bd9684c0f92db7b736986bf894d3a57a714324405823496d13e175e7491): Error starting userland proxy: Bind for 0.0.0.0:49161 failed: port is already allocated.
➜ ~
我诊断:
➜ ~ netstat -anp tcp | grep 49161
tcp4 0 0 192.168.1.2.49161 17.188.166.13.5223 ESTABLISHED
➜ ~
➜ ~ docker --version
Docker version 1.12.5, build 7392c3b
My Dianostic ID:20EB9506-CC72-4093-8A15-60E05A841ED1
我不知道为什么。在那几周之前,它取得了成功。差不多,我改变了,发布了新的DHCP IP。如何运行Docker实例有Oracle 11g表示成功吗?
答案 0 :(得分:8)
你无法启动两次
docker run -d -p 49160:22
因为这意味着你要在主机上分配端口49160两次,当然,第二次,你得到错误信息,尝试第二次运行
docker run -d -p 49161:22
答案 1 :(得分:0)
您需要使用其他端口而不是49161.尝试使用小于49152的端口。
您的计算机上的端口49161与远程Apple服务器上的端口5223之间存在预先存在的连接。因此,在该连接不再存在之前,该端口不能用于任何其他任何东西。端口5223用于Apple的推送通知。据我所知,您的计算机恰好使用随机端口49161连接到Apple的服务器。以前当Docker容器工作时,我打赌你的计算机上的端口49161没有被使用。
每当您连接到远程服务器时,您自己的计算机都会为该连接分配一个随机端口号。这一次,当您的计算机连接到Apple的推送通知服务时,它分配了49161。下一次,它可能是一个完全不同的数字。见https://en.wikipedia.org/wiki/Ephemeral_port