Loading... ## 1. ifconfig > ifconfig命令用于获取网卡配置与网络状态等信息,英文全称为:“interface config”,语法格式为:“<span style='color:green'>ifconfig [参数] [网络设备]</span>”. > 使用ifconfig命令来查看本机当前的网卡配置与网络状态等信息时,其实主要查看的就是网卡名称、inet参数后面的IP地址、ether参数后面的网卡物理地址(又称为MAC地址),以及RX、TX的接收数据包与发送数据包的个数及累计流量(即下面加粗的信息内容): ```bash # ifconfig ens160: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.10.10 netmask 255.255.255.0 broadcast 192.168.10.255 inet6 fe80::c8f8:f5c5:8251:aeaa prefixlen 64 scopeid 0x20 ether 00:0c:29:7d:27:bf txqueuelen 1000 (Ethernet) RX packets 304 bytes 33283 (32.5 KiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 91 bytes 11052 (10.7 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 ``` ## 2. uname(内核+ 架构) > uname命令用于查看系统内核版本与系统架构等信息,英文全称为:“Unix name”,语法格式为:“<span style='color:green'>uname [-a]</span>”. > 在使用uname命令时,一般要固定搭配上-a参数来完整地查看当前系统的内核名称、主机名、内核发行版本、节点名、压制时间、硬件名称、硬件平台、处理器类型以及操作系统名称等信息: > > ```bash > # uname -a > Linux linuxprobe.com 4.18.0-80.el8.x86_64 #1 SMP Wed Mar 13 12:02:46 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux > ``` > 顺带一提,如果要查看当前系统版本的详细信息,则需要查看redhat-release文件,其命令以及相应的结果如下: > > ```bash > # cat /etc/redhat-release > Red Hat Enterprise Linux release 8.0 (Ootpa) > ``` ## 3. uptime(负载) > uptime命令用于查看系统的负载信息,输入后回车执行即可. > uptime命令可以显示当前系统时间、系统已运行时间、启用终端数量以及平均负载值等信息.平均负载值指的是系统在最近1分钟、5分钟、15分钟内的压力情况(0.01, 0.19, 0.18部分),负载值越低越好: > > ```bash > # uptime > 22:49:55 up 10 min, 1 users, load average: 0.01, 0.19, 0.18 > ``` > **Tips** > 负载值越低越好指的是对运维人员来讲的,越低越安全省心.但是公司购置的硬件设备如果长期处于空闲状态,明显是种资源浪费,老板也不会开心.所以我们建议是负载值保持在1左右,不要超过5就好. ## 4. free(内存) > free命令用于显示当前系统中内存的使用量信息,语法格式为:“<span style='color:green'>free [-h]</span>”. > 为了保证Linux系统不会因资源耗尽而突然宕机,运维人员需要时刻关注内存的使用量.在使用free命令时,可以结合使用-h参数以更人性化的方式<span style='color:green'>输出当前内存的**实时**使用量信息</span>. ```bash # free -h ``` | | 内存总量 | 已用量 | 空闲量 | 进程共享的内存量 | 磁盘缓存的内存量 | 缓存的内存量 | 可用量 | | ------- | ---------- | -------- | -------- | ------------------ | ------------------ | -------------- | ----------- | | | total | used | free | shared | buffers | buff/cache | available | | Mem: | 1.9Gi | 1.4Gi | 99Mi | 20Mi | 450Mi | 348Mi | | | Swap: | 2.0Gi | 80Mi | 1.9Gi | | | | | > 如果不使用-h(易读模式)查看内存使用量情况则默认以KB为单位,那服务器如果有几百GB的内存,划算下来就会是一大长串的数字,真不利于阅读. ## 5. who(所有登录用户) > who命令用于查看当前登入主机的用户终端信息,输入后回车执行即可. > who可以快速显示出所有正在登录本机的用户名称以及他们正在开启的终端信息,如果有远程用户,还会显示出来访者的IP地址.表所示为执行who命令后的结果. ```bash # who ``` | 登陆的用户名 | 终端设备 | 登陆到系统的时间 | | -------------- | ---------- | ------------------------- | | root | tty2 | 2020-07-24 06:26 (tty2) | ## 6. last(被访记录) > last命令用于调取主机的被访记录,输入后回车执行即可. > Linux系统会将每次登录信息都记录到日志文件中,如果那天想翻阅了,那就直接执行这条命令就行: ```bash # last root pts/1 192.168.10.1 Tue May 18 10:30 - 11:03 (00:32) root tty2 tty2 Fri Jul 24 06:26 gone - no logout reboot system boot 4.18.0-80.el8.x8 Fri Jul 24 05:59 still running root tty2 tty2 Tue Jul 21 05:19 - down (00:00) reboot system boot 4.18.0-80.el8.x8 Tue Jul 21 05:16 - 05:19 (00:02) wtmp begins Tue Jul 21 05:16:47 2020 ``` ## 7. ping > ping命令用于测试主机之间的网络连通性,语法格式为:“<span style='color:green'>ping [参数] 主机地址</span>”. > 执行ping命令会使用ICMP传输协议发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,以此来判断对方是否在线并且网络正常.ping命令的常见参数以及作用如表所示. | 参数 | 作用 | | ------ | ------------------ | | -c | 总共发送次数 | | -l | 指定网卡名称 | | -i | 每次间隔时间(秒) | | -W | 最长等待时间(秒) | ## 8. tracepath(路由信息) > tracepath命令用于显示数据包达到目的主机途中所经过的路由信息,语法格式为:“<span style='color:green'>tracepath [参数] 域名</span>”. > 当两台主机之间无法正常ping通时,要考虑是否中间有错误的路由信息,导致数据被某一台设备错误丢弃了,这时便可以使用tracepath命令追踪一下所有途径的路由信息,以便分析出是那台设备出了问题,下面的情况就很清晰了: ```bash # tracepath www.linuxprobe.com 1?: [LOCALHOST] pmtu 1500 1: no reply 2: 11.223.0.189 5.954ms asymm 1 3: 11.223.0.14 6.256ms asymm 2 4: 11.220.159.62 3.313ms asymm 3 5: 116.251.107.13 1.841ms 6: 140.205.50.237 2.416ms asymm 5 7: 101.95.211.117 2.772ms 8: 101.95.208.45 40.839ms 9: 101.95.218.217 13.898ms asymm 8 10: 202.97.81.162 8.113ms asymm 9 11: 221.229.193.238 15.693ms asymm 10 12: no reply 13: no reply 14: no reply 15: no reply 16: no reply 17: no reply 18: no reply ………………省略部分输出信息……………… ``` ## 9. netstat(网络信息) > netstat命令用于显示如网络连接、路由表、接口状态等的网络相关信息,英文全称为:“network status”,语法格式为:“<span style='color:green'>netstat [参数]</span>”. > 只要使用得当,便可以查看到网络状态的方方面面信息,我们找出一些常用参数大家感受下吧,netstat命令的常见参数以及作用如表2-12所示. | -a | 显示所有连接中的Socket | | ---- | -------------------------- | | -p | 显示正在使用的Socket信息 | | -t | 显示TCP协议的连接状态 | | -u | 显示UDP协议的连接状态 | | -n | 使用IP地址,不使用域名 | | -l | 仅列出正在监听的服务状态 | | -i | 现在网卡列表信息 | | -r | 显示路由表信息 | > 显示详细的网络状况: > > ```bash > # netstat -a > Active Internet connections (servers and established) > Proto Recv-Q Send-Q Local Address Foreign Address State > tcp 0 0 0.0.0.0:ssh 0.0.0.0:* LISTEN > tcp 0 0 localhost:ipp 0.0.0.0:* LISTEN > tcp 0 0 0.0.0.0:sunrpc 0.0.0.0:* LISTEN > tcp6 0 0 [::]:ssh [::]:* LISTEN > tcp6 0 0 localhost:ipp [::]:* LISTEN > tcp6 0 0 [::]:sunrpc [::]:* LISTEN > udp 0 0 0.0.0.0:bootps 0.0.0.0:* > udp 0 0 0.0.0.0:sunrpc 0.0.0.0:* > udp 0 0 0.0.0.0:mdns 0.0.0.0:* > udp 0 0 0.0.0.0:37396 0.0.0.0:* > udp6 0 0 [::]:sunrpc [::]:* > udp6 0 0 [::]:mdns [::]:* > udp6 0 0 [::]:38541 [::]:* > #………………省略部分输出信息……………… > 显示网卡列表: > # netstat -i > Kernel Interface table > Iface MTU RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg > ens160 1500 70 0 0 0 79 0 0 0 BMRU > lo 65536 248 0 0 0 248 0 0 0 LRU > virbr0 1500 0 0 0 0 0 0 0 0 BMU > ``` #### **10. history** > history命令用于显示执行过的命令历史,语法格式为:“history [-c]”. > history命令应该是运维人员最喜欢的命令.执行history命令能显示出当前用户在本地计算机中执行过的最近1000条命令记录. ```bash # history 1 ifconfig 2 uname -a 3 cat /etc/redhat-release 4 uptime 5 free -h 6 who 7 last 8 ping -c 192.168.10.10 9 ping -c 192.168.10.20 10 tracepath www.linuxprobe.com 11 netstat -a 12 netstat -i 13 history # !3 cat /etc/redhat-release Red Hat Enterprise Linux release 8.0 (Ootpa) ``` <div class="tip inlineBlock warning"> skills 如果觉得1000不够用,可以自定义/etc/profile文件中的HISTSIZE变量值. 在使用history命令时,可以使用-c参数清空所有的命令历史记录. 还可以使用“!编码数字”的方式来重复执行某一次的命令.总之,history命令有很多有趣的玩法等待您去开发. 历史命令会被保存到用户家目录中的.bash_history文件中.Linux系统中以点(.)开头的文件均代表隐藏文件,这些文件大多数为系统服务文件,可以用cat命令查看其文件内容: </div> ```bash # cat ~/.bash_history 要清空当前用户在本机上执行的Linux命令历史记录信息,可执行如下命令: # history -c ``` ## 11. sosreport > sosreport命令用于<span style='color:green'>收集系统配置及架构信息并输出诊断文档</span>,输入后回车执行即可. > 当Linux系统出现故障需要联系技术支持人员时,大多数时候都要先使用这个命令来简单收集系统的运行状态和服务配置信息,以便让技术支持人员能够远程解决一些小问题,亦或让他们能提前了解某些复杂问题. > 在下面的输出信息中,加粗的部分是收集好的资料压缩文件以及校验码,将其发送给技术支持人员: ```bash # sosreport sosreport (version 3.6) This command will collect diagnostic and configuration information from this Red Hat Enterprise Linux system and installed applications. An archive containing the collected information will be generated in /var/tmp/sos.9_i0glu8 and may be provided to a Red Hat support representative. Any information provided to Red Hat will be treated in accordance with the published support policies at: https://access.redhat.com/support/ The generated archive may contain data considered sensitive and its content should be reviewed by the originating organization before being passed to any third party. No changes will be made to system configuration. Press ENTER to continue, or CTRL-C to quit. 此处按下回车键进行确认 Please enter the case id that you are generating this report for []:此处按下回车键进行确认 Setting up archive ... Setting up plugins ... Running plugins. Please wait ... ………………省略部分输出信息……………… Finished running plugins Creating compressed archive... Your sosreport has been generated and saved in: /var/tmp/sosreport-linuxprobe.com-2021-05-18-jnkaspu.tar.xz The checksum is: 9fbecbd167b7e5836db1ff8f068c4db3 Please send this file to your support representative. ``` 最后修改:2022 年 04 月 11 日 © 允许规范转载 打赏 赞赏作者 支付宝微信 赞 0 如果觉得我的文章对你有用,请随意赞赏