docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > Docker映射端口telnet不通

Docker映射端口telnet不通的解决过程

作者:隐0士

这篇文章主要介绍了Docker映射端口telnet不通的解决过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

问题描述

我在自己虚拟机的docker上运行的容器绑定的端口突然跟我的电脑通不了了,在docker启动之后,我使用了netstat -ntalp | grep 3000 发现端口监听shi是正常的,然后就到本机电脑telnet过去发现不通,

一开始怀疑是不是我重启过虚拟机导致防火墙又开启了(临时关闭),但是在虚拟机里面启动了个redis,本机确实能telent6379端口的,而且检查firewalld 和selinux发现都是处于关闭状态,

说明出问题的只是docker的转发出了问题,那转发得先看转发的配置链是否正确,

需要使用iptables -t nat -nL 命令来查看,看起来是对的,于是在想会不会是其他的有问题。

上网找了网友的资料发现

可能是转发得功能没有开,毕竟Linux转发要开启内核转发功能net.ipv4.ip_forward,于是我们可以先检查内核转发是否打开:

输入

sysctl net.ipv4.ip_forward发现

发现状态为0代表内核转发没有打开,估计问题就是这个造成的,于是打开内核转发参数

是处于没有打开的状态

于是我们需要打开它:

[root@dev1 opt]# echo 1 > /proc/sys/net/ipv4/ip_forward
[root@dev1 opt]# sysctl -p

然后本机再次请求发现可以telnet通了。

为什么会出现这个问题,其实是因为docker 的proxy在1.7 版本之后全部都依赖于iptables了,所以docker转发的时候实际上是在iptables上创建了一个转发规则,然后根据这个转发规则来进行转发而iptables需要转发就必须要开启网卡转发功能,也就是net.ipv4.ip_forward要一直处于开启状态。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文