Linux系统常用命令

Linux通常被广泛应用于服务器操作系统领域,绝大多数Linux服务器操作系统默认不提供图形用户界面。服务器管理员需通过命令行界面与Linux服务器进行交互。本文将为您介绍Linux系统中的常用命令。

管理进程

ps

命令介绍

ps命令是Process Status的缩写,用来查看当前系统中正在运行的进程信息快照。

常用参数说明

参数

含义

-A

显示所有程序。

-a

显示现行终端机下的所有程序。

-e

此选项的效果和指定“A”选项相同。

-f

显示UID、PPIP、CSTIME栏位。

-u

以用户为主的格式来显示程序状态。

-U

列出属于该用户的程序的状态,也可以使用用户名来指定。

-x

显示所有程序,不以终端机来区分。

说明

更多参数说明,可运行man ps进行查看。

使用示例

  • 查看所有进程信息。

    ps -ef
  • 通过程序名称关键字查找程序进程信息(指定-e、-f参数)。

    ps -ef | grep <key_word>

    请将上述命令中的<key_word>替换为您指定的关键字。

  • 通过程序名称关键字查找程序进程信息(指定-a、-u、-x参数)。

    ps -aux | grep <key_word>

    请将上述命令中的<key_word>替换为您指定的关键字。

  • 查看进程树信息。

    ps -ejH
  • 查看包含线程数据的进程信息。

    ps -eLf
  • 使用自定义字段格式展示线程信息。

    ps -eo pid,tid,class,rtprio,ni,pri,psr,pcpu,stat,wchan:14,comm
  • 查看指定PID的指标的信息,示例中PID1,指标信息为comm=。

    ps -q 1 -o comm=

top

命令介绍

top命令为Linux系统运行中的进程提供了动态实时视图,可以显示系统的概览信息及Linux内核当前管理的进程列表。

常用参数说明

参数选项

说明

-d

指定top命令刷新频率。

-p

指定PID以监控指定进程的状态。

-s

在安全模式下运行top命令,此模式下将去除交互模式带来的潜在危险。

-i

使top不显示任何闲置或者僵死进程。

-c

显示完整命令而不是只显示命令名称。

资源监控字段说明

下图展示了部分监控字段及其数值,具体数值会因采样周期的不同而有所变化。该图仅供参考,具体数据应以您的实际数据为准。

image

主要参数说明如下

系统摘要信息及进程指标监控字段说明

系统摘要信息字段说明

参数(行)

说明

top

主机名、信息采样日期和时间点。

  • 当前时间

  • up:系统启动时间

  • user:当前登录用户数

  • load average:系统负载,即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

Tasks

各种状态的进程的统计信息。

  • total:所有任务个数。

  • running:运行中进程个数。

  • sleeping:休眠中进程个数。

  • stopped:停止进程个数。

  • zombie:僵尸进程个数。

%Cpu(s)

cpu使用率情况。

  • us:用户空间占CPU的百分比

  • sy:内核空间占CPU的百分比

  • ni:用户进程空间改变过优先级

  • id:空闲CPU占用率

  • wa:等待输入输出的CPU时间百分比

  • hi:硬中断占用百分比

  • si:软中断占用百分比

  • st:steal time

MiB Mem

内存使用量统计。

  • total:物理内存总量。

  • free:空闲内存量

  • used:使用的内存量

  • buff/cache:用作内核缓存的内存量。

MiB Swap

交换分区使用量统计。

  • total:交换区内存总量。

  • free:空闲交换区总量。

  • used:使用的交换区总量。

  • avail Mem:缓冲的交换区总量。

进程列表指标信息字段说明

参数(列)

说明

PID

进程的ID

USER

进程所属用户

PR

进程的优先级别,越小越优先被执行

NI

进程优先值

VIRT

进程占用的虚拟内存

RES

进程占用的物理内存

SHR

进程使用的共享内存

S

进程的状态。

  • R:运行状态。

  • S:休眠状态。

  • Z:僵死状态。

  • D:不可中断的睡眠状态

  • T:跟踪/停止状态

%CPU

进程占用CPU的使用率

%MEM

进程使用的物理内存和总内存的百分比

TIME+

该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。

COMMAND

进程启动命令名称

使用示例

  • 按指定采集频率查看系统指标

    运行如下命令,按指定采集频率展示系统指标。示例中指定采集频率为3 秒一次。

    top 3
    说明

    执行top命令,默认会以5s的采集频率展示系统指标。

  • 定制top命令指标展示界面

    默认情况下top命令展示的指标如系统摘要信息及进程指标监控字段说明所示。如需修改展示的指标界面,您可以在top交互式命令界面下按f键,以便筛选您需要的指标视图。

    image

    在视图字段管理界面,相关操作,请参见下表。

    按键

    说明

    ↑,↓

    进行字段选择。

    选择整列,之后可以使用上下键移动整列的显示位置。

    空格

    选择隐藏还是显示该字段,带*的为显示。

    s

    将当前光标所在列设置为排序列。

    q

    退出视图字段管理界面。

  • 使用top命令的交互模式

    运行top命令后,系统将进入交互模式。在该模式下,用户可以通过按键与命令进行交互。有关交互模式所支持的命令,请参见下表。

    按键

    说明

    1

    展示每个逻辑CPU的指标状况。

    u

    u键之后,输入Linux系统用户名,可以查看该用户相关的进程。

    E

    切换内存指标的计量单位,在Kib、MiB、GiB、TiB、PiB、EiB之间切换。

    x

    显示排序列。

    y

    显示运行中的进程。

    ?

    显示帮助信息。

  • 通过PID号找到对应的进程名及所在目录

    执行top命令动态显示进程信息。 以aliyun-service程序为例,查看到PID1325 。 image

    执行以下命令查看对应程序的目录。

    cd /proc/1352
    ls -ail

    image

kill

命令介绍

kill命令用于在Linux中手动结束进程。

常用参数说明

参数

说明

-l

列出可用的信号的名称。

-L

在表格中列出信号名称。

使用示例

  • 杀死所有可以杀死的进程。

    sudo kill -9 -1
  • 显示信号编号 11 所代表的信号名称。

    sudo kill -l 11
  • 在表格中列出所有可用的信号。

    sudo kill -L
  • 结束指定PID的进程。

    sudo kill -9 <PID>

    请将上述命令中的<PID>替换为您指定的进程PID。

killall

命令介绍

killall命令用于在Linux中通过进程名称结束进程。

常用参数说明

参数

说明

-g

杀死属于该进程组的进程。

-i

交互模式,杀死进程前会征求确认信息。

-v

报告信号是否成功发送。

使用示例

杀死top进程。

sudo killall top

查看系统信息

在使用Linux实例过程中,可以使用uname命令查询系统信息。

uname

命令介绍

uname命令用于输出系统信息。

常用参数说明

选项

说明

-a

输出全部信息。

-s

输出内核名称。

-n

输出网络节点主机名。

-r

输出内核发行版本。

-v

输出内核版本信息。

-m

输出机器硬件名称。

-P

输出处理器类型。

-i

输出硬件平台信息。

-o

输出操作系统信息。

使用示例

查看全部系统信息。

uname -a

dmidecode

dmidecode 命令主要用于从Linux系统 BIOS(基本输入输出系统)中提取和显示与硬件相关的信息。它读取 DMI(桌面管理接口)表,提供关于计算机硬件配置的详细信息,包括但不限于:

  1. 系统信息:包括制造商、产品名称、版本、序列号、系统型号等。

  2. 处理器信息:包括处理器的型号、速度、核心数等信息。

  3. 内存信息:包括内存插槽的数量、容量、类型、速度等信息。

  4. 主板信息:包括主板的制造商、版本、序列号等。

  5. BIOS 信息:包括 BIOS 的版本、发布日期等。

  6. 电源信息:电源相关的规格和型号。

  7. 设备信息:包括各种硬件组件的信息,如网络适配器等。

  • 输出系统的完整 DMI 信息。

    sudo dmidecode

    预期结构如下:

  • 如果只想查看特定的DMI信息,可以使用 -t 参数,例如仅输出与内存相关的信息:

    sudo dmidecode -t memory

    预期结果如下:

    # dmidecode 3.5
    Getting SMBIOS data from sysfs.
    SMBIOS 2.8 present.
    
    Handle 0x1000, DMI type 16, 23 bytes
    Physical Memory Array
            Location: Other
            Use: System Memory
            Error Correction Type: Multi-bit ECC
            Maximum Capacity: 16 GB
            Error Information Handle: Not Provided
            Number Of Devices: 1
    
    Handle 0x1100, DMI type 17, 40 bytes
    Memory Device
            Array Handle: 0x1000
            Error Information Handle: Not Provided
            Total Width: Unknown
            Data Width: Unknown
            Size: 16 GB
            Form Factor: DIMM
            Set: None
            Locator: DIMM 0
            Bank Locator: Not Specified
            Type: RAM
            Type Detail: Other
            Speed: Unknown
            Manufacturer: Alibaba Cloud
            Serial Number: Not Specified
            Asset Tag: Not Specified
            Part Number: Not Specified
            Rank: Unknown
            Configured Memory Speed: Unknown
            Minimum Voltage: Unknown
            Maximum Voltage: Unknown
            Configured Voltage: Unknown

查看物理CPU和内存信息

说明
  • 总核数 = 物理CPU个数 × 每颗物理CPU的核数

  • 总逻辑CPU数 = 物理CPU个数 × 每颗物理CPU的核数 × 超线程数

通过如下命令,可以查看物理CPU和内存相关信息。

  • 查看物理CPU个数。

    cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l
  • 查看每个物理CPUcore的个数,即CPU核数。

    cat /proc/cpuinfo| grep "cpu cores"| uniq
  • 查看逻辑CPU的个数。

    cat /proc/cpuinfo| grep "processor"| wc -l
  • 查看CPU型号。

    cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c
  • 查看内存信息。

    cat /proc/meminfo

查看管理磁盘

df

命令介绍

df命令用于报告文件系统磁盘空间使用情况。

常用参数说明

选项

说明

-a

包含伪(pseudo)、重复和无法访问的文件系统。

-B

输出前将块大小转换为指定大小。

-h

以 1024 为幂显示大小(例如,1023M)。

-H

以 1000 为幂输出大小(例,1.1G)。

-k

等效于 --block-size=1K。

-l

仅列出本地的文件系统。

-t

只显示指定类型的文件系统信息。

使用示例

查看磁盘空间使用情况,结果以MB为单位。

df -BM

回显结果示例如下。

Filesystem     1M-blocks  Used Available Use% Mounted on
tmpfs               742M   22M      721M   3% /run
/dev/vda3         39943M 2542M    35556M   7% /
tmpfs              3708M    0M     3708M   0% /dev/shm
tmpfs                 5M    0M        5M   0% /run/lock
tmpfs               742M    1M      742M   1% /run/user/0

lsblk

命令介绍

lsblk命令用于列出块设备信息。

常用参数说明

参数

说明

-a

列出所有设备,包含空设备及内存盘设备。

-b

SIZE列使用bytes作为输出。

-f

输出信息中包含文件系统。

使用示例

  • 查看块设备信息,包含文件系统信息。

    lsblk -f

    回显结果示例如下。

    NAME   FSTYPE FSVER LABEL UUID                                 FSAVAIL FSUSE% MOUNTPOINTS
    vda                                                                           
    |-vda1                                                                        
    |-vda2 vfat   FAT32       6175-F96E                                           
    `-vda3 ext4   1.0         df02e0a1-d28d-41b1-99c2-58f2b684cc79   34.7G     6% /
  • 获取磁盘序列号SN。

    不同Linux发行版获取方法可能存在差异,以下方法适用于Alibaba Cloud Linux 3/CentOS 7/Ubuntu18。参考以下步骤进行操作。

    1. 查看系统挂载的块存储设备。

      lsblk
    2. 使用以下命令获取存块储设备的磁盘序列号SN,此处以vda设备为例。

      udevadm info --query=all --name=/dev/vda | grep ID_SERIAL

blkid

命令介绍

blkid命令用于查看块设备属性信息。

使用示例

查看块设备属性信息

blkid  /dev/vda

回显结果示例如下。

/dev/vda: PTUUID="bdee1c7f-46fc-4838-9a74-9exxxxxxxxaf" PTTYPE="gpt"

fdisk

命令介绍

fdisk命令是Linux分区表操作工具。

常用参数说明

参数

说明

-l

列出指定设备的分区表信息。

-u

以扇区数而不是以柱面数的形式显示分区表中各分区的信息。

使用示例

查看设备分区情况。

sudo fdisk -lu

回显结果示例如下。

Disk /dev/vda: 40 GiB, 42949672960 bytes, 83886080 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: gpt
Disk identifier: BDEE1C7F-46FC-4838-9A74-9E57F8FD63AF

Device      Start      End  Sectors  Size Type
/dev/vda1    2048     4095     2048    1M BIOS boot
/dev/vda2    4096   413695   409600  200M EFI System
/dev/vda3  413696 83886046 83472351 39.8G Linux filesystem

mount

命令介绍

mount命令用于挂载一个文件系统。

常用参数说明

参数

说明

-a

挂载所有在/etc/fstab文件中描述的文件系统。

-L

以给定的标签挂载分区。

-r

以只读模式挂载文件系统。

-w

以读写模式挂载文件系统。

-U

以指定的uuid挂载分区。

使用示例

  • 挂载fstab中配置的所有文件系统。

    sudo mount -a
  • 以读写模式挂载指定文件系统。

    sudo mount -w /dev/vdb1 /mnt

umount

命令介绍

umount命令用于卸载一个文件系统。

常用参数说明

参数

说明

-r

如果卸载失败,尝试以只读方式重新挂载。

-a

卸载所有在/etc/mtab文件中描述的文件系统。

-t

只卸载指定类型的文件系统。如果要一次指定多个文件系统, 可以用逗号分隔。

-f

强制卸载。

使用示例

强制卸载指定分区。

sudo umount -f /dev/vdb1

管理服务

systemctl

命令介绍

systemctl命令用于服务管理。

常用参数说明

参数

说明

-a

表示列出所有已加载的单元或者属性。

常用单元命令

命令

说明

start

启动指定的已加载单元。

stop

停止指定的已加载单元。

restart

重新启动指定的已加载单元。

reload

要求指定的单元重新加载它们的配置。

status

显示指定单元的运行时状态信息。常见的服务运行状态如下所示。

  • active (running):服务正在后台运行。

  • active (exited):服务已经运行过并已退出。

  • active (waiting):该服务正在运行,但正在等待由特定条件或事件触发。

  • inactive:服务当前未运行。

常用单元文件命令

命令

说明

enable

启用指定的单元或单元实例。

disable

停用指定的单元或单元实例。

使用示例

  • 重新启动nginx服务。

    sudo systemctl restart nginx
  • 查看nginx服务状态。

    sudo systemctl status nginx
  • 设置nginx服务开机启动。

    sudo systemctl enable nginx

管理资源占用

lsof

命令介绍

lsof命令用于列出打开的文件。

说明

如果您使用的Linux发行版没有预装lsof工具,您可以使用对应的软件包管理工具进行安装。

  • Alibaba Cloud Linux、CentOS、RHEL:sudo yum install lsof

  • Ubuntu、Debian:sudo apt install lsof

常用参数说明

参数

说明

-p

输出指定进程打开的文件。

-l

输出中使用ID代替用户名。

-u

输出指定用户打开的文件。

-c

输出COMMAND列中包含指定关键字的项。

-d

输出包含指定描述符的项。

-i

输出符合指定条件的项。可选参数如下:

  • 46:分别指 IPv4、IPv6。

  • protocol:可指定TCPUDP。

  • hostname:网络主机名。

  • hostaddr:IP 地址。

  • service:包含在/etc/services中的名称。

  • port:端口号,可以是多个。

回显信息说明

运行lsof命令后的回显信息示例如下:

image

相关参数说明如下。

参数

说明

COMMAND

命令名称。

PID

进程ID。

TID

线程ID,如果为空代表列出的是进程。

TASKCMD

任务名称,通常与 COMMAND 相同。

USER

用户ID号或登录名。

FD

文件描述符。

TYPE

与文件关联的节点类型。

DEVICE

设备号。

SIZE/OFF

文件大小/偏移量,以字节为单位。

NODE

文件结点。

NAME

文件挂载点和文件所在的系统。

使用示例

  • 列出指定进程打开的文件

    sudo  lsof -p 1

    请将上述命令中的1进程PID替换为您指定的进程PID。

  • 查看指定用户相关进程打开的文件

    sudo lsof -u <user-name>

    请将上述命令中的<user-name>替换为您指定的Linux系统用户名。

  • 查看打开指定文件的相关进程信息

    sudo lsof <file-name>

    请将上述命令中的<file-name>替换为您指定的文件名。

  • 输出 TYPE 为 IPv4 的所有项

    sudo lsof -i 4

netstat

命令介绍

netstat命令用于显示TCP、UDP的端口和进程等相关情况。

常用参数说明

参数

说明

-t

仅显示TCP相关选项。

-u

仅显示UDP相关选项。

-i

显示网卡列表。

-n

拒绝显示别名,能显示数字的全部转化为数字。

-l

仅列出在Listen(监听)的服务状态。

-p

显示建立相关链接的程序名。

-s

显示网络统计信息。

使用示例

  • 查看8000端口的占用情况。

    netstat -tunlp | grep 8000

    请将上述命令中的8000端口替换为您指定的进程PID。

  • 查看所有TCP端口使用情况。

    netstat -ntlp

获取用户登录信息

Linux系统中用户登录记录相关文件说明如下。

  • 用户登录信息通常记录在/var/run/utmp/var/log/wtmp/var/log/btmp/var/log/lastlog等文件中。

  • whowusers等命令通过/var/run/utmp文件查询当前登录用户的信息。

  • last命令通过/var/log/wtmp文件查询当前与过去登录系统的用户的信息。

  • lastb命令通过/var/log/btmp文件查询所有登录系统失败的用户的信息。

  • lastlog命令通过/var/log/lastlog文件查询用户最后一次登录的信息。

who

who命令用于查看当前登录系统的用户信息,返回结果类似如下。

image

w

w命令显示当前登录的用户名并显示该用户当前执行的任务,返回结果类似如下。

image

users

users命令用于显示当前登录的用户名,返回结果类似如下。

image

last

last命令用于查看截止当前登录过系统的所有用户信息,返回结果类似如下。

image

lastb

lastb命令显示所有登录系统失败的用户的信息,返回结果类似如下。

image

lastlog

lastlog命令用于查看用户最后一次登录系统的信息,返回结果类似如下。

image

cat /var/log/secure

cat /var/log/secure命令用于查询所有用户登录系统的记录,返回结果类似如下。

image

管理用户

Linux系统中,您可以通过useraddwheelpasswduserdel等命令有效地管理系统用户及其权限。

useradd

命令介绍

useradd 命令主要用于添加新用户。该命令和adduser功能基本相同。创建完成后,您可以通过cat /etc/passwd | grep username查看用户信息。

  • 在创建用户时,需要root权限或相应的sudo权限。

  • 使用 useradd 创建用户后,建议立即设置用户密码。

  • 确保在创建用户时,主组和附加组是存在的,否则会导致添加用户失败。

常用参数说明

参数

说明

-d

指定用户的主目录。如果不指定,系统会使用默认的 /home/用户名 作为主目录。

-m

创建用户的主目录。如果指定了 -d 选项,同时也添加此选项,则会创建该目录。

-s

指定用户的登录 Shell,默认是 /bin/bash

-g

指定用户的主组。如果组不存在,则需要先创建。

-G

指定用户加入的附加组。多个附加组直接用英文逗号隔开。

-p

为用户设置密码。注意,该密码需要经过加密,不应直接在命令行中使用明文密码。示例如下:

sudo useradd -p $(openssl passwd -6 '明文密码') newusername

-u

指定用户的用户ID。

-e

设置账户的有效期,格式为 YYYY-MM-DD。

使用示例

  • 创建一个新用户 jack,并为其指定主目录和登录 Shell目录:

    useradd -m -d /home/jack -s /bin/bash jack

    创建完成后,您可以通过cat /etc/passwd | grep jack查看到如下信息:

    jack:x:1000:1000::/home/jack:/bin/bash

    用户创建后,可以使用 passwd 命令为用户设置密码:

    passwd jack
  • 创建一个新用户 alice,并将其添加到 developers 组:

    useradd -m -G developers alice
  • 创建一个新用户 bob,并设置用户ID为 1001:

    useradd -m -u 1001 bob
  • 添加拥有root权限的用户。步骤如下:

    重要

    建议遵循安全最佳实践,仅在必要的情况下授予用户root权限。

    1. 使用 useradd 命令创建一个新用户john

      useradd john
    2. 为新创建的用户设置密码。

      passwd john
    3. 为了让新用户拥有 root 权限,可以将用户添加到 wheel 组中。wheel 组通常用于授予用户 sudo 权限。执行grep '^wheel:' /etc/group查询wheel组成员。

      sudo usermod -aG wheel john
    4. 测试新用户的sudo权限。切换到新用户,并尝试使用 sudo 命令:

      su - john
      sudo ls /root

      如果一切正常,会被要求输入密码,输入正确的密码后,系统将列出 /root 目录的内容,表明新用户拥有 sudo 权限,也可以使用john进行远程登录。

    5. (可选)修改sudoers文件。在文件中,为用户添加特定的权限。

      sudo visudo

userdel

命令介绍

userdel 命令主要用于删除用户账户。

常用参数说明

参数

说明

-r

同时删除用户的主目录和该目录下的文件。

-f

强制删除用户,即使用户当前正在登录。

使用示例

  • 删除用户 john

    切换到root用户,执行cat /etc/passwd | grep john查看用户目录,返回如下信息,

    john:x:1001:1001::/home/john:/bin/bash

    删除名为 john 的用户,但其用户目录和文件仍然会保留。

    userdel john
  • 删除用户 john 及其用户目录和所有与该用户相关的文件,

    userdel -r username
  • 强制删除用户,即使该用户当前正在使用系统。

    userdel -f username

wheel

命令介绍

wheel 是一个用户组,主要功能是控制谁可以使用 su 命令切换到超级用户账户(通常是root用户)。

  • wheel 组默认已经存在。如果不存在,可以使用sudo groupadd wheel命令创建。

  • 默认的情况下,普通用户通过su命令且输入了正确的root密码,就可以切换到root用户,对系统进行管理和配置。

  • 为了加强系统的完全性,可以使用Linux特殊的wheel用户组来限制普通用户切换到root管理员用户,只有加入到wheel组,才可以使用su切换到root管理员用户。

使用示例

  • 检查用户是否在 wheel 组中。

    groups username
  • 将用户添加到 wheel 组中。

    sudo usermod -aG wheel username

    使用 visudo 命令安全编辑/etc/sudoers 文件,%wheel ALL=(ALL) ALL表示 wheel 组的成员可以使用 sudo 执行所有命令。

    如果想要允许 wheel 组的用户无密码使用 sudo,可以修改为:

    %wheel ALL=(ALL) NOPASSWD: ALL