Linux 因没通过反向路由检查而drop报文
问题现象
# 93816ef1ab90是ubuntu:23.10,ip是172.17.0.2 docker run -itd 93816ef1ab90 bash
主机可以ping通该容器。
删除容器内默认路由和子网路由后,无法ping通。
问题分析
nettrace -p icmp --daddr 172.17.0.2 --diag --ret
https://elixir.bootlin.com/linux/v6.5/source/net/ipv4/fib_frontend.c#L421
内核函数fib_validate_source返回1,没通过反向路由检查,说明容器收包和回包不是同一个网口。
这里,容器没有路由,不存在回包网口。
解决问题
容器网卡增加默认路由。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
2023-07-30 k8s timeoutSeconds无效且没有按照periodSeconds的间隔时间来执行健康检查
2023-07-30 vmware虚拟机增加虚拟网卡
2023-07-30 Linux TCP Socket实现进程间通信