1. 首页 > 娱乐

一篇讲明白监控运维命令

监控类命令

watch命令

watch命令是一个用于在命令行界面下执行指定命令或脚本,并周期性地显示其输出结果的实用程序。它可以帮助你监视命令的实时输出,以便持续跟踪命令的执行情况。

watch命令的常见语法如下:

watch [选项] 命令

其支持的选项如下:

通过使用watch命令,你可以方便地监视系统状态、实时查看日志文件的变化、观察进程的运行情况等。它在调试和监控系统时非常有用,以及在需要持续追踪某些命令输出的情况下使用。

后面跟双引号

如果连接的命令比较长,可以使用双引号括起来的方式 例如:

watch -n 5 -d "ps -aux | grep java"

ps命令

ps命令是一个用于查看当前正在运行的进程信息的实用程序。它提供了多种用法和选项,以下是一些常见的用法:

ps -ef --forest
ps -f --forest -p <PID>
ps -ef --forest --forest
ps -ef | grep <进程名>
ps -u <用户名>

pstree命令

pstree命令是一个用于以树状结构显示进程层次关系的实用程序。它以可读性较好的方式显示进程之间的父子关系,帮助用户更好地理解和分析系统中的进程结构。

pstree命令通常在Linux和Unix系统中预装,无需额外安装。你可以直接在终端中使用该命令。下面是使用pstree命令的基本语法:

pstree [选项]

一般情况下,你可以直接运行pstree命令来显示当前用户的所有进程及其层次关系。它会以树状结构的形式输出进程层次,并标示进程之间的父子关系。

pstree命令还提供一些选项来定制其行为,例如:

你可以组合使用这些选项来满足你的需求,例如:pstree -p -h会显示进程的PID,并以高亮方式突出显示当前进程及其祖先进程。

需要注意的是,pstree命令可能需要以超级用户(root)权限运行,以显示所有进程的完整层次结构。你可以使用sudo pstree命令来获取完整的进程层次信息。

free 命令

free命令用于显示系统的内存使用情况和交换空间(swap)情况。下面是free命令的详细用法:

free [选项]

常用的选项包括:

以下是一些常用的示例:

free命令的输出结果包括以下字段:

这些字段描述了系统内存的不同方面和用途。以下是这些字段之间的关系:

总体上,used包括了shared、buffers、cached和实际被进程使用的内存。而free则表示未被系统和进程使用的内存,包括未被缓冲和缓存的空闲内存。

需要注意的是,这些值是基于当前时刻的快照,内存使用情况是动态变化的,因此在不同时间查询时,这些值可能会有所不同。

df命令、du命令和fdisk命令

这三个命令都是查看硬盘使用情况的命令

df命令

df命令用于显示文件系统的磁盘空间使用情况。它提供了多种选项,用于定制输出的格式和内容。以下是一些常用的选项:

可以使用这些选项的组合来满足特定的需求。例如:

df -h -x <文件系统类型>
df -i --total

请注意,<文件系统类型>是指文件系统的标识,如ext4、ntfs、vfat等。你可以通过df --help命令获取完整的选项列表和用法说明。

du命令

du命令用于显示目录或文件的磁盘空间使用情况。它可以帮助你确定文件和目录所占用的磁盘空间大小。以下是一些常用的du命令选项:

你可以使用这些选项的组合来满足不同的需求。以下是一些示例:

du -h <目录或文件>
du -sh <目录>
du -a <目录>
du --max-depth=2 <目录>

请注意,<目录或文件>是指要查看磁盘空间使用情况的目录路径或文件路径。你可以通过du --help命令获取完整的选项列表和用法说明。

fdisk命令

fdisk命令是一个用于查看和管理磁盘分区的命令行工具。它可以帮助你查看磁盘的分区信息、创建新的分区、删除分区等。以下是一些常用的fdisk命令选项:

fdisk /dev/sda

请注意,使用fdisk命令进行分区操作需要以超级用户(root)权限运行。此外,对磁盘进行分区操作是一个潜在的危险操作,请确保在进行分区操作之前备份重要的数据。

以下是一个简单的分区操作示例:

fdisk /dev/sda

查看cpu情况

top命令

PID USERPRNIVIRTRESSHR S%CPU%MEMTIME+ COMMAND

1692815 root 20 0 17.7g 1.5g 20264 S 6.3 4.7 5:53.00 java

以上是top命令的一个结果,我们来简单解读一下:

`:任务占用的内存百分比。

以上是对top命令结果的详细解释,它提供了关于系统任务、CPU、内存和进程的重要信息。top命令有许多选项可以用于定制输出和控制显示的内容。以下是一些常用的top命令选项:

mpstat命令

下面是该命令的一次结果

Linux 5.10.0-15-amd64 (debian-2) 06/07/2023x86_64(16 CPU) 03:01:22 PM CPU %usr %nice %sys %iowait %irq %soft %steal %guest %gnice %idle 03:01:22 PM all 0.22 0.00 0.19 0.00 0.00 0.00 0.00 0.00 0.00 99.59

简单解读一下

下面是每一列的含义:

对于示例中的数据行:

这些统计信息显示了在报告生成的时间点上,系统中的 CPU 使用情况。

下面是一些常用的mpstat命令选项:

查看网络情况

netstat命令

netstat命令有多个选项,可以根据需要来显示网络连接、路由表和网络统计信息。以下是一些常用的netstat命令选项:

下面是一个结果

Proto RefCnt Flags Type State I-Node PID/Program name Path unix 2 [ ] DGRAM 579005 26313/systemd /run/user/0/systemd/notify unix 2 [ ACC ] STREAM LISTENING 13693 1228/zabbix_server /run/zabbix/zabbix_server_rtc.sock

逐行进行分析:

这些信息提供了关于网络连接的详细信息,包括连接类型、状态、进程关联和相关路径。

ss命令

ss命令是用于查看套接字(socket)信息的工具,具有比netstat更快速和更强大的功能。以下是一些常用的ss命令选项:

看看例子

State Recv-Q Send-Q Local Address:Port Peer Address:Port ProcessESTAB 0 0 20.20.40.232:ssh 10.110.0.9:23033CLOSE-WAIT 32 0 xxx.xxx.xxx.xxx:58836 xxx.xxx.xxx.xxx:https

逐行分析为: 根据提供的ss命令结果,逐行进行分析:

这些信息提供了关于套接字的详细信息,包括套接字状态、数据队列大小和本地/远程地址与端口。

traceroute命令

traceroute命令用于跟踪数据包从本地主机到目标主机的路径。它通过发送一系列的数据包,逐跳地测量和显示每个跳点的延迟和路径信息。以下是一些常用的traceroute命令选项:

traceroute命令的结果通常会显示每个跳点的信息,包括跳点的序号、IP地址、主机名(如果可解析)、延迟和跃点数(TTL)。以下是traceroute命令可能显示的一些常见结果:

需要注意的是,由于网络环境的变化和路由策略的差异,不同跟踪的结果可能会有所不同。

当traceroute命令的结果中,IP地址列显示为星号(*)时,表示无法获得该跳点的IP地址信息。这通常是因为网络设备或防火墙配置的原因,导致无法获取到该跳点的准确IP地址。这种情况下,traceroute无法确定经过的网络节点具体的IP地址。可能的原因包括:

在这种情况下,traceroute仍然会显示其他可用信息,如跳点的序号、延迟时间和跃点数(TTL),但无法提供具体的IP地址。

telnet命令

telnet命令是一个用于远程登录或测试网络连接的工具。以下是telnet命令的一些常见选项:

和traceroute类似

ifconfig命令

ifconfig命令用于查看和配置网络接口的信息,包括IP地址、网络掩码、MAC地址等。以下是一些常见的ifconfig命令选项:

这些只是ifconfig命令的一些常用选项,实际上还有更多选项和功能可用。为了获取详细的选项列表和用法说明,您可以在命令行中输入man ifconfig以查看ifconfig命令的手册页。请注意,ifconfig在一些新的Linux发行版中已被ip命令所取代,因此建议尽量使用ip命令进行网络接口的配置和管理。

来看一个例子

eno1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 20.20.40.232 netmask 255.255.248.0 broadcast 20.20.47.255 inet6 fe80::2eea:7fff:fe93:ef5e prefixlen 64 scopeid 0x20 ether 2c:ea:7f:93:ef:5e txqueuelen 1000 (Ethernet) RX packets 39320669 bytes 46025532065 (42.8 GiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 37370 bytes 5499509583 (5.1 GiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 device interrupt 17lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536 inet 127.0.0.1 netmask 255.0.0.0 inet6 ::1 prefixlen 128 scopeid 0x10loop txqueuelen 1000 (Local Loopback) RX packets 5399237 bytes 819904930 (781.9 MiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 5399237 bytes 819904930 (781.9 MiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

根据提供的输出,我们可以分析两个网络接口:eno1和lo。

综上所述,eno1是一个活动的以太网接口,具有IPv4和IPv6地址,而lo是一个本地环回接口,用于在本地进行回环测试和通信。

杀死进程的kill命令

kill命令可以发送不同的信号给进程,以便控制其行为。以下是一些常见的kill命令信号及其对应的编号:

除了上述常见的信号外,还有其他信号可供使用,具体的信号列表可以通过kill -l命令查看。该命令会列出系统支持的所有信号及其对应的编号。

例如,可以通过以下命令查看信号列表:

杀死某个名称的进程

ps -aux | grep 'python3 main.py' | awk '{print $2}' | xargs kill -9

kill、pkill和killall命令

kill、pkill和killall命令都用于终止正在运行的进程,但它们在使用方式和作用范围上有所不同。

常用选项:

需要注意的是,使用这些命令时要小心确认要终止的进程,以免意外关闭重要的进程。在使用强制终止信号(如9号信号)时,进程可能无法进行正常的清理操作,因此建议在必要时使用,并确保备份数据。

本网站的文章部分内容可能来源于网络和网友发布,仅供大家学习与参考,如有侵权,请联系站长进行删除处理,不代表本网站立场,转载者并注明出处:https://jmbhsh.com/yule/36532.html

联系我们

QQ号:***

微信号:***

工作日:9:30-18:30,节假日休息