【Linux技术专题】「夯实基本功系列」带你一同学习和实践操作Linux服务器必学的Shell指令(排查问题指令 - 下)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 在线上排查问题时,查询日志、查看系统配置和分析操作系统信息是至关重要的。这些操作可以帮助我们深入了解软件和服务的兼容性,并解决潜在的问题。在本次学习中,我们将介绍并深入学习一些我在处理类似问题时常用的指令。通过掌握这些指令,你将能够更加高效地定位和解决线上问题,提高系统的稳定性和性能。让我们一同进入这个学习过程吧!

前提介绍

在线上排查问题时,查询日志、查看系统配置和分析操作系统信息是至关重要的。这些操作可以帮助我们深入了解软件和服务的兼容性,并解决潜在的问题。在本次学习中,我们将介绍并深入学习一些我在处理类似问题时常用的指令。通过掌握这些指令,你将能够更加高效地定位和解决线上问题,提高系统的稳定性和性能。让我们一同进入这个学习过程吧!

主要的指令分为一下几大类
在这里插入图片描述

more和less命令用法

more命令

more命令是类似于cat命令的功能,但它将文件的内容分页显示在屏幕上。与cat命令一次性显示整个文件不同,more命令通过一页一页的方式方便用户逐页阅读文件。

基本的more命令操作如下:

  • 按空格键(space)向下翻一页显示内容。
  • b键向上(back)翻一页显示内容。
  • more命令还具有搜索字符串的功能,可以在文件中查找指定的字符串。

more命令从前向后读取文件,因此在启动时就加载整个文件。它会根据终端的大小自动决定每页显示的行数,以适应屏幕空间。

使用more命令可以方便地分页阅读文件内容,尤其适用于查看较大的文件或输出较长的文本内容。

命令格式

more [-dlfpcsu ] [-num ] [+/ pattern] [+ linenum] [file ... ]

命令参数

more命令的一些常用选项和功能如下:

  • +n 从第n行开始显示文件内容
  • -n 定义屏幕显示的行数为n行
  • +/pattern 在每个文件显示前,在指定的模式(pattern)前进行搜索,然后从该模式的前两行之后开始显示内容
  • -c 清屏并显示文件内容
  • -d 提示用户按空格键继续显示内容,按q键退出,并禁用响铃功能
  • -l 忽略Ctrl+l(换页)字符
  • -p 使用清除窗口而不是滚屏的方式进行分页,类似于-c选项
  • -s 将连续的多个空行显示为一行
  • -u 去除文件内容中的下划线

常用操作命令

more命令的一些常用操作快捷键和功能说明:

  • Enter:向下滚动一行或指定的行数(默认为1行)
  • Ctrl+F:向下滚动一屏
  • 空格键:向下滚动一屏
  • Ctrl+B:返回上一屏
  • =:输出当前行的行号
  • ::显示当前文件名和当前行的行号
  • V:调用vi编辑器进行编辑
  • !命令:调用Shell,并执行指定的命令
  • q:退出more命令

通过使用这些操作快捷键,可以更灵活地浏览和操作more命令中显示的文件内容。例如,可以通过回车键或者空格键逐行或指定行数滚动文件内容,使用Ctrl+F或空格键快速向下滚动一屏,使用Ctrl+B返回到上一屏,并使用其他功能来获取更多的信息。

案例分析

显示文件中从第3行起的内容

使用了两个命令来显示文件的内容。首先是使用cat命令来显示test.log文件的所有日志内容。然后,使用more命令来从第三行开始显示日志内容。

cat test.log                 # 显示所有日志内容
more +3 test.log             # 从第三行开始显示日志内容

通过这些命令,我们可以很方便地查看文件的特定部分,例如从指定行开始显示内容,以满足我们的需求。

将日志内容设置为每屏显示4行

使用more命令将日志文件test.log的每屏显示行数设置为4行。这意味着每次显示文件内容时,最多只会显示4行,方便用户逐页阅读。

more -4 test.log

通过调整-4参数的值,您可以根据需要设置不同的每屏显示行数,以便更好地控制和浏览文件内容。

快速定位和显示文件中包含特定字符串

使用more命令从文件test.log中查找并定位第一个出现"liu"字符串的行,并从该处前两行开始显示输出。

more +/liu test.log

在这个示例中,+/liu参数告诉more命令在每个文件显示前,在文件中搜索"liu"字符串,并从该字符串的前两行后开始显示文件内容,以方便用户查看与该字符串有关的内容。

结合管道和more命令来分页显示

当一个目录下的文件内容太多时,可以结合管道和more命令来分页显示,通过使用管道和more命令,可以处理文件内容太多而无法一次显示的情况。管道将前一个命令的输出作为后一个命令的输入,实现数据的流动和处理。

命令:

cat test.log | more -5

在这个示例中,使用管道|cat命令的输出作为输入传递给more命令。这样可以将文件test.log的内容通过管道传递给more命令,并结合-5参数使其每页显示5行内容。

less指令

less工具是对文件或其他输出进行分页显示的工具,在Linux中被认为是查看文件内容的正统工具,并具有非常强大的功能。less相比于more更加灵活和弹性。在使用more时,我们无法向前翻页,只能向后查看内容。但是,使用less时,可以使用[pageup][pagedown]等按键来往前往后翻页,更方便查看文件内容。此外,在less中还拥有更多的搜索功能,不仅可以向下搜索,还可以向上搜索。

使用less命令可以方便地浏览文件内容,并且具有更多的交互和搜索功能,使得查看文件变得更加便捷和高效。

命令格式

less [参数]  文件

less命令的一些常用选项和功能如下:

  • -b <缓冲区大小>:设置缓冲区的大小
  • -e:当文件显示结束后,自动离开
  • -f:强制打开特殊文件,例如外围设备代号、目录和二进制文件
  • -g:只标记最后搜索的关键词
  • -i:忽略搜索时的大小写
  • -m:显示类似more命令的百分比
  • -N:显示每行的行号
  • -o <文件名>:将less输出的内容保存到指定文件中
  • -Q:不使用警告音
  • -s:将连续的空行显示为一行
  • -S:当行过长时将超出部分舍弃
  • -x <数字>:将tab键显示为指定数量的空格

    搜索指令操作

  • /字符串:向下搜索指定的字符串

  • ?字符串:向上搜索指定的字符串
  • n:重复前一个搜索(与/?有关)
  • N:反向重复前一个搜索(与/?有关)
  • b:向后翻一页
  • d:向后翻半页
  • h:显示帮助界面
  • Q:退出less命令
  • u:向前滚动半页
  • y:向前滚动一行
  • 空格键:滚动一行
  • 回车键:滚动一页
  • [pagedown]:向下翻动一页
  • [pageup]:向上翻动一页

与more的对比

less 与 more 类似,但使用 less 可以随意浏览文件,而 more 仅能向前移动,却不能向后移动,而且 less 在查看之前不会加载整个文件。

查看CPU使用率的几个命令

在Linux系统维护中,常用以下几个命令来查看CPU使用率和相关信息:

top命令

这个命令很常用,在第三行有显示CPU当前的使用情况,可以实时显示系统的运行情况,包括CPU使用率、运行队列等。使用命令top,然后按"1"可以查看每个核心的CPU使用率。

[root@li676-235 ~]# top -bn 1 -i -c
top - 14:19:51 up 138 days, 7:15, 1 user, load average: 0.20, 0.33, 0.39
Tasks: 115 total, 1 running, 114 sleeping, 0 stopped, 0 zombie
Cpu(s): 4.5%us, 3.8%sy, 0.0%ni, 91.0%id, 0.6%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 1014660k total, 880512k used, 134148k free, 264904k buffers
Swap: 262140k total, 34788k used, 227352k free, 217144k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
12760 root 20 0 15084 1944 1632 R 2.0 0.2 0:00.01 top -bn 1 -i -c

如上所示,top命令可以提供总体的系统运行状态和CPU的使用率信息。

  • %us:表示用户空间程序的CPU使用率(没有通过nice调度)。
  • %sy:表示系统空间的CPU使用率,主要是内核程序。
  • %ni:表示用户空间且通过nice调度过的程序的CPU使用率。
  • %id:表示空闲CPU的比例。
  • %wa:表示CPU运行时在等待IO的时间。
  • %hi:表示CPU处理硬中断的数量。
  • %si:表示CPU处理软中断的数量。
  • %st:表示被虚拟机偷走的CPU的比例。

通过观察这些指标,可以了解系统的整体负载和CPU的使用情况。例如,高 %us 表示用户程序占用CPU较多,高 %wa 可能表示IO等待较多。这些信息有

mpstat命令

可以显示每个CPU的统计数据,包括用户空间、系统空间和空闲时间的百分比。使用命令mpstat,例如:

   mpstat -P ALL

vmstat命令

可以显示系统的虚拟内存、进程、IO等信息,其中包括CPU使用率和上下文切换。使用命令vmstat,例如:

   vmstat -n 1
[root@li676-235 ~]# vmstat 1 5
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r b swpd free buff cache si so bi bo in cs us sy id wa st
 2 0 34792 68376 147688 356132 16 16 421 385 2 2 5 4 91 1 0
 3 0 34792 97368 147688 326884 0 0 0 0 133 134 15 6 79 0 0
 1 0 34792 62432 147696 360704 0 0 0 88 267 278 63 18 19 0 0
 0 0 34792 97160 147696 326904 0 0 0 0 71 82 12 4 84 0 0
 1 0 34792 56572 147696 364540 0 0 0 4 261 246 61 23 16 0 0

sar命令

可以以历史记录的方式显示CPU使用率和其他系统指标。使用命令sar,例如:

   sar -u

这些命令可以用来监控CPU的性能指标,帮助评估系统的运行情况和性能瓶颈。根据需要选择合适的命令来查看CPU使用率和相关信息。

CPU使用率

例如每1秒采集一次CPU使用率,共采集5次。

[root@li676-235 ~]# sar -u 1 5
Linux 3.18.5-x86_64-linode52 (li676-235) 07/20/2015 _x86_64_ (1 CPU)
02:41:25 PM CPU %user %nice %system %iowait %steal %idle
02:41:26 PM all 64.71 0.00 18.63 0.00 0.98 15.69
02:41:27 PM all 29.47 0.00 22.11 14.74 0.00 33.68
02:41:28 PM all 67.33 0.00 31.68 0.99 0.00 0.00
02:41:29 PM all 7.00 0.00 2.00 0.00 0.00 91.00
02:41:30 PM all 69.00 0.00 23.00 0.00 0.00 8.00
Average: all 47.79 0.00 19.48 3.01 0.20 29.52

和top一样,可以看到所有cpu的使用情况。如果需要查看某颗cpu的使用可以用-P参数。例如指定显示0号cpu 的使用情况。

[root@li676-235 ~]# sar -P 0 -u 1 5
Linux 3.18.5-x86_64-linode52 (li676-235) 07/20/2015 _x86_64_ (1 CPU)
02:45:14 PM CPU %user %nice %system %iowait %steal %idle
02:45:15 PM 0 44.00 0.00 52.00 4.00 0.00 0.00
02:45:16 PM 0 9.28 0.00 26.80 62.89 1.03 0.00
02:45:17 PM 0 3.06 0.00 14.29 81.63 1.02 0.00
02:45:18 PM 0 4.12 0.00 22.68 72.16 1.03 0.00
02:45:19 PM 0 4.12 0.00 22.68 72.16 1.03 0.00
Average: 0 13.09 0.00 27.81 58.28 0.82 0.00

进程队列长度和平均负载状态

例如每1秒采集一次,共采集5次。

[root@li676-235 ~]# sar -q 1 5
Linux 3.18.5-x86_64-linode52 (li676-235) 07/20/2015 _x86_64_ (1 CPU)
02:48:47 PM runq-sz plist-sz ldavg-1 ldavg-5 ldavg-15
02:48:48 PM 1 133 0.34 0.43 0.41
02:48:49 PM 2 132 0.34 0.43 0.41
02:48:50 PM 1 133 0.34 0.43 0.41
02:48:51 PM 2 134 0.31 0.42 0.40
02:48:52 PM 1 133 0.31 0.42 0.40
Average: 1 133 0.33 0.43 0.41

输出项

  • runq-sz:运行队列的长度(等待运行的进程数)
  • plist-sz:进程列表中进程(processes)和线程(threads)的数量
  • ldavg-1:最后1分钟的系统平均负载(System load average)
  • ldavg-5:过去5分钟的系统平均负载
  • ldavg-15:过去15分钟的系统平均负载

进程创建的平均值和上下文切换的次数

例如每1秒收集一次,共收集5次。

[root@li676-235 ~]# sar -w 1 5 
Linux 3.18.5-x86_64-linode52 (li676-235) 07/20/2023 _x86_64_ (1 CPU)
02:54:03 PM proc/s cswch/s
02:54:04 PM 1.01 156.57
02:54:05 PM 1.00 132.00
02:54:06 PM 2.00 201.00
02:54:07 PM 2.02 126.26
02:54:08 PM 2.00 114.00
Average: 1.61 145.98
相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
1月前
|
存储 机器学习/深度学习 人工智能
硅谷GPU单节点服务器:技术解析与应用全景
“硅谷GPU单节点服务器”代表了在单个物理机箱内集成强大计算能力,特别是GPU加速能力的高性能计算解决方案。它们并非指代某个特定品牌,而是一类为处理密集型工作负载而设计的服务器范式的统称。
|
6月前
|
存储 机器学习/深度学习 数据库
阿里云服务器X86/ARM/GPU/裸金属/超算五大架构技术特点、场景适配参考
在云计算技术飞速发展的当下,云计算已经渗透到各个行业,成为企业数字化转型的关键驱动力。选择合适的云服务器架构对于提升业务效率、降低成本至关重要。阿里云提供了多样化的云服务器架构选择,包括X86计算、ARM计算、GPU/FPGA/ASIC、弹性裸金属服务器以及高性能计算等。本文将深入解析这些架构的特点、优势及适用场景,以供大家了解和选择参考。
1145 61
|
3月前
|
弹性计算 安全 Linux
阿里云服务器ECS安装宝塔Linux面板、安装网站(新手图文教程)
本教程详解如何在阿里云服务器上安装宝塔Linux面板,涵盖ECS服务器手动安装步骤,包括系统准备、远程连接、安装命令执行、端口开放及LNMP环境部署,手把手引导用户快速搭建网站环境。
|
4月前
|
人工智能 运维 安全
MCP协议深度解析:客户端-服务器架构的技术创新
作为一名长期关注AI技术发展的博主摘星,我深刻感受到了MCP(Model Context Protocol)协议在AI生态系统中的革命性意义。MCP协议作为Anthropic公司推出的开放标准,正在重新定义AI应用与外部系统的交互方式,其基于JSON-RPC 2.0的通信机制为构建可扩展、安全的AI应用提供了坚实的技术基础。在深入研究MCP协议规范的过程中,我发现这一协议不仅解决了传统AI应用在资源访问、工具调用和上下文管理方面的痛点,更通过其独特的三大核心概念——资源(Resources)、工具(Tools)、提示词(Prompts)——构建了一个完整的AI应用生态系统。MCP协议的客户端-
445 0
MCP协议深度解析:客户端-服务器架构的技术创新
|
6月前
|
监控 Linux 应用服务中间件
Linux多节点多硬盘部署MinIO:分布式MinIO集群部署指南搭建高可用架构实践
通过以上步骤,已成功基于已有的 MinIO 服务,扩展为一个 MinIO 集群。该集群具有高可用性和容错性,适合生产环境使用。如果有任何问题,请检查日志或参考MinIO 官方文档。作者联系方式vx:2743642415。
2193 57
|
4月前
|
监控 Linux 网络安全
FinalShell SSH工具下载,服务器管理,远程桌面加速软件,支持Windows,macOS,Linux
FinalShell是一款国人开发的多平台SSH客户端工具,支持Windows、Mac OS X和Linux系统。它提供一体化服务器管理功能,支持shell和sftp同屏显示,命令自动提示,操作便捷。软件还具备加速功能,提升访问服务器速度,适合普通用户和专业人士使用。
1276 0
|
6月前
|
数据挖掘 Linux 数据库
服务器数据恢复—Linux系统服务器数据恢复案例
服务器数据恢复环境: linux操作系统服务器中有一组由4块SAS接口硬盘组建的raid5阵列。 服务器故障: 服务器工作过程中突然崩溃。管理员将服务器操作系统进行了重装。 用户方需要恢复服务器中的数据库、办公文档、代码文件等。
|
7月前
|
Linux Shell
shell_42:Linux参数移动
总的来说,参数移动是Linux shell脚本中的一个重要概念,掌握它可以帮助我们更好地处理和管理脚本中的参数。希望这个解释能帮助你理解和使用参数移动。
164 18
|
7月前
|
存储 机器学习/深度学习 算法
阿里云X86/ARM/GPU/裸金属/超算等五大服务器架构技术特点、场景适配与选型策略
在我们选购阿里云服务器的时候,云服务器架构有X86计算、ARM计算、GPU/FPGA/ASIC、弹性裸金属服务器、高性能计算可选,有的用户并不清楚他们之间有何区别。本文将深入解析这些架构的特点、优势及适用场景,帮助用户更好地根据实际需求做出选择。
|
7月前
|
安全 网络安全 定位技术
网络通讯技术:HTTP POST协议用于发送本地压缩数据到服务器的方案。
总的来说,无论你是一名网络开发者,还是普通的IT工作人员,理解并掌握POST方法的运用是非常有价值的。它就像一艘快速,稳定,安全的大船,始终为我们在网络海洋中的冒险提供了可靠的支持。
248 22