docker部署容器端口占用问题
当我在使用 Windows 下使用 Docker Desktop 部署docker容器时经常性发生容器启动失败的提示,并且有的时候重启电脑后就能成功启动容器,这是因为 Hyper-V 引起的 保留端口,这部分端口将会被系统保留,无法被其他应用程序所使用
一、错误日志
在部署容器时报如下错误
Error invoking remote method 'docker-start-container':
Error: (HTTP code 500) server error - Ports are not available:
listen tcp 0.0.0.0:6379: bind: An attempt was made to access a socket in a way forbidden by its access permissions.
二、解决方法
(1)方法一(只是端口被别的程序占用)
查看被占用的端口号
netstat -aon|findstr "6379"
杀死进程
taskkill /f /pid 3884
查看被占用的端口号
ps -ef | grep 6379
杀死进程
kill -9 506
(1)方法二
当查看端口号未被占用时可能是Hyper-V 会保留部分tcp端口,开始到结束范围内的端口不可用, 使用如下命令查看保留的端口
netsh interface ipv4 show excludedportrange protocol=tcp
可以得到
可以看到1883、6379、8806、50059
端口在排除范围内
此时可以修改容器启动命令(主要是修改端口)重新启动容器。
这种是绕过了被保留的端口, 如果你的程序一定要使用范围内的端口,有如下三种方式
-
临时关闭
Hyper-y
法-
临时关闭
Hyper-V
-
配置端口
-
恢复
Hyper-V
-
-
重启电脑
- 保留的端口是随机的,每次重启电脑都会改变,因此可以通过重启电脑来解决。
-
永久排除保留大纲
-
使用如下命令
netsh int ipv4 add excludedportrange protocol=tcp startport=6379 numberofports=1 store=persistent netsh interface ipv4 show excludedportrange protocol=tcp # 再次查看保留端口
-
得到如下结果
-
6379后有*说明已被排除
参考文章:https://blog.csdn.net/crayon0/article/details/127444776