Linux: network: ping不通的原因之一:route设置

在Linux的ip route命令输出中,比如下面一条(属于subnet路由,是专业叫法/称谓)。

135.2.0.0/16 dev eth2 proto kernel scope link src 135.2.221.111

具体字段含义:

135.2.0.0/16: 这是目标网络,即当数据包的目标地址在135.2.0.0/16这个网段内时,使用这条路由。【这个网段范围有点大,首先要怀疑配置问题。如果配置有问题会导致一个不同步,当ping另一个ip的时候,如果这个目的地址恰巧落在这个subnet路由里,但是实际又不属于这个subnet网段,这个时候就会有ping失败的问题。】

dev eth2: 指定这条路由与网络接口eth2相关联,数据包会通过eth2接口发送。

proto kernel: 表示这条路由是由内核自动生成的。

scope link: 表示这条路由的作用范围为本地链路(link-local),通常表示路由的下一跳在同一个网络段内。会尝试做arp request,请求目的地址,或者说在同一网段的ip地址对应的mac地址。

src 135.2.221.111: 这个字段明确指出,当匹配这条路由时,系统将使用135.2.221.111作为数据包的源IP地址。

src字段的作用:

指定默认源地址: 如果系统需要向135.2.0.0/16网络中的某个IP地址发送数据包,而没有通过其他方式(例如套接字绑定)指定源地址,系统将使用路由表中src字段指定的IP地址作为源地址。

多网卡配置: 在多网卡配置下,系统通常会通过src字段来明确指定数据包的源地址,以确保数据包的源IP地址与所使用的网络接口匹配。

避免IP冲突或路由异常: 通过指定src地址,可以确保发出数据包的源地址与正确的子网匹配,防止由于错误的源地址配置而引发网络问题。

所以这里可以看到当前这个route的设置,说明这个局域网设置的subnet内的ip地址非常多,也就是非常大的subnet。一般是代表不太合理。

如果这个时候,arp request没有得到arp reply,就会出现ping不通的问题。

相关推荐
分布式存储与RustFS几秒前
RustFS保姆级教程:Docker快速部署兼容S3的本地对象存储
运维·docker·容器·rustfs部署教程·本地搭建s3对象存储·rustfs网页控制台使用·awscli连接rustfs
江湖有缘几秒前
Docker部署Papra极简文件归档平台
运维·docker·容器
gooxi_hui20 分钟前
海量存力,智驭未来丨国鑫4U60盘位高密度存储服务器SL401-G4重磅上市
运维·服务器·人工智能
吴爃25 分钟前
小微企业 SRE 稳定性建设
运维·稳定性·小微企业
天空'之城29 分钟前
Linux 系统编程 10:线程同步
linux·开发语言·系统编程·线程同步
河铃旅鹿1 小时前
在Ubuntu系统上为Android交叉编译OpenSSL
android·linux·ubuntu
开开心心_Every1 小时前
带OCR识别的电子发票打印工具
运维·自动化·ocr·电脑·powerpoint·音视频·lua
长孙豪翔1 小时前
引发事件的问题
java·linux·数据库
小张成长计划..1 小时前
【Linux】7:第一个系统程序-进度条
linux·运维·服务器
2401_885411471 小时前
linux进程间通信------命名管道
linux·运维·服务器