如何使用OSI七层模型的思路进行Linux网络问题排障?

news2025/2/6 17:12:06

在运维工作中,我们可能经常遇到诸如服务器无法远程连接、网站无法访问等各种网络问题。此时你是否想过,我们常背的OSI七层模型,能在处理这样的实际问题中发挥什么样的作用呢?

基于OSI架构的方法论,我们可以使用自下而上的方法论来进行网络故障排查。

什么是OSI模型

OSI,即开放系统互连(Open Systems Interconnection),该模型是一个概念框架,它将网络通信的功能划分为七个不同的层级。简单来说,OSI标准定义了不同计算机系统之间如何进行通信。七层模型自下而上分别为:
OSI七层模型

如何运用OSI模型排查网络故障

假设有一个托管在Linux服务器上的网站无法正常工作,那么我们可以使用OSI模型对问题进行有效分解。

物理层

物理层是最底层,这一层的关键组件是电缆、光纤等物理介质。在这个层次上,我们可以检查电源供应及设备状态,查看接口统计信息。常用的命令如ifconfigip link show

[root@ecs-91176055 ~]#  ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.0.4  netmask 255.255.255.0  broadcast 192.168.0.255
        inet6 fe80::f816:3eff:fe03:78e  prefixlen 64  scopeid 0x20<link>
        inet6 2409:8c3c:ffff:3b10::1a  prefixlen 128  scopeid 0x0<global>
        ether fa:16:3e:03:07:8e  txqueuelen 1000  (Ethernet)
        RX packets 400  bytes 299740 (292.7 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 405  bytes 90337 (88.2 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 32  bytes 2520 (2.4 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 32  bytes 2520 (2.4 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@ecs-91176055 ~]#  ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000
    link/ether fa:16:3e:03:07:8e brd ff:ff:ff:ff:ff:ff

如果结果中有接口显示down,则表明物理层未能正常运行。 有时候物理连接是正常的,但网卡并未激活,可以尝试使用如下命令拉起接口:

ifconfig eth0 up
# 或
ip link set eth0 up

另外ethtool也是非常有用的工具,它提供了查询和修改设置的能力,可以调整诸如速率、端口、自动协商等参数。

[root@ecs-91176055 ~]#  ethtool eth0
Settings for eth0:
        Supported ports: [  ]
        Supported link modes:   Not reported
        Supported pause frame use: No
        Supports auto-negotiation: No
        Supported FEC modes: Not reported
        Advertised link modes:  Not reported
        Advertised pause frame use: No
        Advertised auto-negotiation: No
        Advertised FEC modes: Not reported
        Speed: Unknown!
        Duplex: Unknown! (255)
        Auto-negotiation: off
        Port: Other
        PHYAD: 0
        Transceiver: internal
        Link detected: yes

数据链路层

数据链路层使连接到同一网络的两台设备能够传输数据。该层包含两个部分。第一个组成部分是介质访问控制(MAC)层,涉及硬件寻址和访问控制操作。第二个部分是逻辑链路层,它能够在不同媒介间建立逻辑连接。

本层常见问题之一是两台服务器无法建立连接,此时可以使用pingtraceroutearp以及Wireshark等工具对数据链路层进行测试,验证同一网络组内设备之间数据帧是否正确传输和接收。

网络层

网络层的作用是确保数据能够在两个网络之间顺畅流动,在网络层工作的设备是路由器。路由器的主要任务是简化网络之间的通信,处理IP地址是这一层的工作内容。

在这个阶段,我们主要应查找与IP地址相关的问题,例如可以通过ip -br address show来查看地址,确认网卡是否已分配到IP地址。

[root@ecs-91176055 ~]#  ip -br address show
lo               UNKNOWN        127.0.0.1/8 ::1/128 
eth0             UP             192.168.0.4/24 2409:8c3c:ffff:3b10::1a/128 fe80::f816:3eff:fe03:78e/64 

如果您使用DHCP获取IP地址,那么可能是没有从DHCP获得动态IP地址。

另一个常见的问题是缺少特定路由或路由指向错误,导致数据包无法通过网关发出或走到了错误的网关。了解数据报到达最终目的地址的路由,在排查跨网络通信时尤其重要。我们可以通过ip route命令查看和管理路由表,也可以通过向默认网关或远端网关发送ping请求来检查连通性。

[root@ecs-91176055 ~]#  ip route
default via 192.168.0.1 dev eth0 proto dhcp metric 100 
192.168.0.0/24 dev eth0 proto kernel scope link src 192.168.0.4 metric 100 
 
[root@ecs-91176055 ~]#  ip -6 route
::1 dev lo proto kernel metric 256 pref medium
2409:8c3c:ffff:3b10::1a dev eth0 proto kernel metric 100 pref medium
2409:8c3c:ffff:3b10::/64 dev eth0 proto ra metric 100 pref medium
fe80::/64 dev eth0 proto kernel metric 100 pref medium
default via fe80::6a54:edff:fe00:7f1c dev eth0 proto ra metric 100 pref medium

[root@ecs-91176055 ~]#  ping 192.168.0.1 -c 4
PING 192.168.0.1 (192.168.0.1) 56(84) bytes of data.
64 bytes from 192.168.0.1: icmp_seq=1 ttl=64 time=0.095 ms
64 bytes from 192.168.0.1: icmp_seq=2 ttl=64 time=0.096 ms
64 bytes from 192.168.0.1: icmp_seq=3 ttl=64 time=0.097 ms
64 bytes from 192.168.0.1: icmp_seq=4 ttl=64 time=0.120 ms

--- 192.168.0.1 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3099ms
rtt min/avg/max/mdev = 0.095/0.102/0.120/0.010 ms

传输层

传输层使用传输控制协议(TCP)和用户数据报协议(UDP)等协议来控制系统间的网络流量,确保数据高效流动。传输层负责发送数据包,查找错误,控制数据流,并将其按序排列。

在这个层面遇到的问题,可能是监听端口未开启等。如果服务启动失败,可能是因为端口已被占用。可以运行netstatss命令查看哪些端口正在监听,并判断你需要连接的端口是否正由正确的程序监听。

[root@ecs-91176055 ~]#  netstat -ntupl
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1245/sshd: /usr/sbi 
tcp        0      0 0.0.0.0:44321           0.0.0.0:*               LISTEN      1478/pmcd           
tcp        0      0 0.0.0.0:4330            0.0.0.0:*               LISTEN      2752/pmlogger       
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN      743/rpcbind         
tcp6       0      0 :::22                   :::*                    LISTEN      1245/sshd: /usr/sbi 
tcp6       0      0 :::44321                :::*                    LISTEN      1478/pmcd           
tcp6       0      0 :::4330                 :::*                    LISTEN      2752/pmlogger       
tcp6       0      0 :::111                  :::*                    LISTEN      743/rpcbind         
udp        0      0 0.0.0.0:60469           0.0.0.0:*                           743/rpcbind         
udp        0      0 0.0.0.0:111             0.0.0.0:*                           743/rpcbind         
udp6       0      0 :::52026                :::*                                743/rpcbind         
udp6       0      0 :::111                  :::*                                743/rpcbind         
udp6       0      0 fe80::f816:3eff:fe0:546 :::*                                829/NetworkManager  
 
[root@ecs-91176055 ~]#  ss -ntupl
Netid               State                Recv-Q                Send-Q                                                 Local Address:Port                                Peer Address:Port               Process                                                 
udp                 UNCONN               0                     0                                                            0.0.0.0:60469                                    0.0.0.0:*                   users:(("rpcbind",pid=743,fd=7))                       
udp                 UNCONN               0                     0                                                            0.0.0.0:111                                      0.0.0.0:*                   users:(("rpcbind",pid=743,fd=6))                       
udp                 UNCONN               0                     0                                                               [::]:52026                                       [::]:*                   users:(("rpcbind",pid=743,fd=10))                      
udp                 UNCONN               0                     0                                                               [::]:111                                         [::]:*                   users:(("rpcbind",pid=743,fd=9))                       
udp                 UNCONN               0                     0                                    [fe80::f816:3eff:fe03:78e]%eth0:546                                         [::]:*                   users:(("NetworkManager",pid=829,fd=25))               
tcp                 LISTEN               0                     128                                                          0.0.0.0:22                                       0.0.0.0:*                   users:(("sshd",pid=1245,fd=3))                         
tcp                 LISTEN               0                     5                                                            0.0.0.0:44321                                    0.0.0.0:*                   users:(("pmcd",pid=1478,fd=0))                         
tcp                 LISTEN               0                     5                                                            0.0.0.0:4330                                     0.0.0.0:*                   users:(("pmlogger",pid=2752,fd=7))                     
tcp                 LISTEN               0                     4096                                                         0.0.0.0:111                                      0.0.0.0:*                   users:(("rpcbind",pid=743,fd=8))                       
tcp                 LISTEN               0                     128                                                             [::]:22                                          [::]:*                   users:(("sshd",pid=1245,fd=4))                         
tcp                 LISTEN               0                     5                                                               [::]:44321                                       [::]:*                   users:(("pmcd",pid=1478,fd=3))                         
tcp                 LISTEN               0                     5                                                               [::]:4330                                        [::]:*                   users:(("pmlogger",pid=2752,fd=8))                     
tcp                 LISTEN               0                     4096                                                            [::]:111                                         [::]:*                   users:(("rpcbind",pid=743,fd=11))        

最常遇到的问题是无法与远端端口建立连接,这是可以使用telnet命令进行连通性测试:

[root@ecs-91176055 ~]#  telnet 192.168.0.6 6443
Trying 192.168.0.6...
Connected to 192.168.0.6.
Escape character is '^]'.

如果要检查远程UDP端口,则可以使用netcat工具(nc命令)。

会话层

会话层负责协调两个设备之间的通信发起和终止过程,通信发起和终止的时间段及称为会话。

在这个层面,可以检查凭据、服务器证书、客户端的会话ID和cookies等内容。

表示层

表示层负责将数据转换为能够呈现给用户的形式。

在这个网站访问的例子中,SSLTLS加密方法是这一层的关键组成部分。在这一层,我们可以检查加密和解密方面的问题。

应用层

系统在此层接收用户的输入并将输出返回给用户。我们熟知的FTP、SMTP、SSH、IMAP、DNS、HTTP等协议均运行在这一层级。

在这个阶段,我们可以检查服务器上的配置文件是否存在错误。此外,还可以查看服务器日志文件以获取有关问题的更多详细信息。

结论

我们从底层开始逐层向上探索,针对OSI模型的每一层介绍了各种专用工具和排查思路。尽管实际生产环境会复杂得多,但这种方法论确是通用的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1598607.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OpenHarmony轻量系统开发【5】驱动之GPIO点灯

5.1点灯例程源码 先看最简单得LED灯闪烁操作 源码结构如下&#xff1a; 第一个BUILD.gn文件内容&#xff1a; static_library("led_demo") {sources ["led_demo.c"]include_dirs ["//utils/native/lite/include","//kernel/liteos_m/c…

FL Studio v21.2.3.4004 中文永久版网盘下载(含Key.reg注册表补丁)

软件介绍 FL Studio21水果编曲软件汉化版是一款专业的音乐制作软件&#xff0c;被广泛地应用于电子音乐、hip-hop、流行乐等多种音乐类型的制作。该软件提供了丰富的音频编曲工具和音乐效果器&#xff0c;让用户可以轻松地创作出高品质的音乐作品。同时&#xff0c;这也是一款…

配置优先级标记和队列调度示例

配置优先级标记和队列调度示例 组网图形 图1 优先级标记和队列调度示例组网图 优先级标记和队列调度简介配置注意事项组网需求配置思路操作步骤配置文件 优先级标记和队列调度简介 报文进入设备之后&#xff0c;设备会根据相应的规则分配或修改报文各种优先级的值&#xff…

Spring 事务失效总结

前言 在使用spring过程中事务是被经常用的&#xff0c;如果不小心或者认识不做&#xff0c;事务可能会失效。下面列举几条 业务代码没有被Spring 容器管理 看下面图片类没有Componet 或者Service 注解。 方法不是public的 Transactional 注解只能用户public上&#xff0c…

51单片机入门_江协科技_29~30_OB记录的自学笔记_DS18B20温度传感器

29. DS18B20温度传感器 29.1. DS18B20介绍 •DS18B20是一种常见的数字温度传感器&#xff0c;其控制命令和数据都是以数字信号的方式输入输出&#xff0c;相比较于模拟温度传感器&#xff0c;具有功能强大、硬件简单、易扩展、抗干扰性强等特点 •测温范围&#xff1a;-55C 到 …

k8s的service为什么不能ping通?——所有的service都不能ping通吗

点击阅读原文 前提&#xff1a;kube-proxy使用iptables模式 Q service能不能ping通&#xff1f; A: 不能&#xff0c;因为k8s的service禁止了icmp协议 B: 不能&#xff0c;因为clusterIP是一个虚拟IP&#xff0c;只是用于配置netfilter规则&#xff0c;不会实际绑定设备&…

腾讯EdgeOne产品测评体验—Web服务全能一体化服务,主打一步到位

前言 现在网络Web攻击真的防不胜防啊&#xff0c;相信有很多独狼开发者自己建站&#xff0c;租个云服务器&#xff0c;一部署自己的服务&#xff0c;每隔一段时间内测和网站总有一个要崩。自己感觉难受不说&#xff0c;网站稍微有点要出头的时候&#xff0c;数不清的访问攻击就…

汽车车灯用肖特基二极管,选什么型号好?

肖特基二极管种类繁多&#xff0c;有低压降肖特基二极管、通用型肖特基二极管、快速恢复型肖特基二极管、高功率肖特基二极管、汽车级肖特基二极管等等&#xff0c;其中低压降肖特基二极管和汽车级肖特基二极管是二极管厂家东沃电子的核心优势产品。关于东沃电子推出的低压降肖…

FFmpeg: 自实现ijkplayer播放器--05ijkplayer–连接UI界面和ffplay.c

文章目录 ijkplayer时序图消息循环--回调函数实现播放器播放时状态转换播放停止ijkmediaPlay成员变量成员函数ijkplayer时序图 stream_open: frame_queue_init packet_queue_init init_clock 创建read_thread线程 创建video_refresh_thread线程 消息循环–回调函数实现 ui 和…

Spectral Adversarial MixUp for Few-Shot Unsupervised Domain Adaptation论文速读

文章目录 Spectral Adversarial MixUp for Few-Shot Unsupervised Domain Adaptation摘要方法Domain-Distance-Modulated Spectral Sensitivity (DoDiSS&#xff09;模块Sensitivity-Guided Spectral Adversarial Mixup (SAMix)模块 实验结果 Spectral Adversarial MixUp for F…

在线教程|低门槛部署!SUPIR 专治各种图片模糊,还能理解文本描述进行精修

家庭相册中泛黄的老照片&#xff0c;历史档案中尘封的影像资料&#xff0c;科研实验中沉淀下的图片资源…… 图像作为一种重要的信息载体&#xff0c;不仅承载了消逝的时光与故事&#xff0c;也记录着人类对历史的探索和传承。然而&#xff0c;由于早期保存条件的限制&#xf…

Go 编译构建的一些细节

Go 编译构建的一些细节 发现自己竟然没有怎么认真研究过 go 的编译构建命令。 结论前置 go run 专门用来运行命令源码文件的命令&#xff0c;一般用来运行单个文件go build 主要是用于测试编译。编译某个包或者项目&#xff0c;在当前目录下生成可执行文件go install 编译并…

(4)步态识别论文研读——用于步态识别的分层时空表示学习

论文题目Hierarchical Spatio-Temporal Representation Learning for Gait Recognition 论文地址 https://arxiv.org/abs/2307.09856 1.摘要 步态识别是一种生物特征技术&#xff0c;通过其独特的行走方式识别个体&#xff0c;适用于无约束环境&#xff0c;具有广泛的应用。…

链表OJ1——删除链表中等于给定值 val 的所有节点

题目 力扣OJ链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 解法 我们来看看这个题目啊&#xff0c;怎么做呢&#xff1f; 有两种解法 三指针法 我们完全可以定义三个指针来进行这个删除操作 假设我们要移除的是2 这样子就完成了 特殊情况 开头——假设我们…

一文速览铁威马TOS 6全新“文件管理”

TOS 6 Beta已经上线一段时间了&#xff0c;各位铁粉用着怎么样呢&#xff1f;今天就和大家分享&#xff0c;TOS 6全新文件管理。 为了向用户提供更流畅、更便捷的文件管理体验&#xff0c;铁威马的研发团队积极借鉴了Windows OS和Mac OS在文件管理方面的优点&#xff0c;投入巨…

系统学c#:2、基础语法(关键字、标识符、数据类型、变量、常量、字面量、运算符、类型转换)

关键字&#xff1a; 关键字是编程语言中具有特殊含义的单词或符号&#xff0c;它们通常被编程语言用于表示特定的语法结构、操作或约定。在C#中&#xff0c;关键字具有特定的语法和功能&#xff0c;用于定义语言的基本结构和规则。 以下是一些C#中常用的关键字及其功能&#xf…

使用colab进行yolov5小demo练习

输入一张动物的图片进行目标检测和分类 !pip install yolov5 import torch from PIL import Image from torchvision import transforms from yolov5.models.experimental import attempt_load from yolov5.utils.general import non_max_suppression# 加载YOLOv5模型 device …

Gradle 构建自动化工具入门

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 目录 1. 前言 2. 简介 3. 常见的项目构建工具 4. 安装 4.1. 安装说明 4.2. 下载…

【小风扇/移动电源升压芯片方案】FP6291是一款异步内置MOS管升压恒压芯片 小封装(SOT23-6)设计简单外围器件少

芯片概述 FP6291是一款异步内置MOS管升压恒压芯片&#xff0c;与肖特基和电感形成回路组成升压架构&#xff1b; 工作电压2.6-5.5V&#xff0c;可适用已单节电池和5V供电升压&#xff1b; 恒压基准&#xff08;VFB&#xff09;为0.6V2%&#xff0c;误差小提高输出的准确度&…

前端开发攻略---用JavaScript将数字转换为中文。支持万亿以下的正整数;深入解析:JavaScript 函数详解数字转换为中文的实现原理与流程

1、演示 2、实现思路 函数名为 toChineseNumber&#xff0c;它的作用是将一个数字转换成对应的中文表示形式。这个函数是一个自定义的实现&#xff0c;通过一系列步骤将数字转换成中文。我会逐步解释每一部分&#xff0c;以确保您对代码的理解清晰明了。 首先&#xff0c;让我们…