新手必须掌握的Linux命令

标题

文章内容参考整理自书籍《Linux就该这么学》

速查表

主命令 功能/作用
tar tar命令用于对文件进行打包压缩或解压,语法格式为“tar 参数 文件名称”。
file file命令用于查看文件的类型,语法格式为“file 文件名称”。
dd dd命令用于按照指定大小和个数的数据块来复制文件或转换文件,语法格式为“dd if=参数值of=参数值count=参数值bs=参数值”。
rm rm命令用于删除文件或目录,英文全称为“remove”,语法格式为“rm [参数] 文件 名称”。
mv mv命令用于剪切或重命名文件,英文全称为“move”,语法格式为“mv [参数] 源文件名称 目标文件名称”。
cp cp命令用于复制文件或目录,英文全称为“copy”,语法格式为“cp [参数] 源文件名称 目标文件名称”。
mkdir mkdir命令用于创建空白的目录,英文全称为“make directory”,语法格式为“mkdir [参数] 目录名称”。
touch touch命令用于创建空白文件或设置文件的时间,语法格式为“touch [参数] 文件名称”。
sort sort命令用于对文本内容进行再排序,语法格式为“sort [参数] 文件名称”。
uniq uniq命令用于去除文本中连续的重复行,英文全称为“unique”,语法格式为“uniq [参数] 文件名称”。
diff diff命令用于比较多个文件之间内容的差异,英文全称为“different”,语法格式为“diff [参数] 文件名称A 文件名称B”。
cut cut命令用于按“列”提取文本内容,语法格式为“cut [参数] 文件名称”。
grep grep命令用于按行提取文本内容,语法格式为“grep [参数] 文件名称”。
stat stat命令用于查看文件的具体存储细节和时间等信息,英文全称为“status”,语法格式为“stat 文件名称”。
wc wc命令用于统计指定文本文件的行数、字数或字节数,英文全称为“word counts”,语法格式为“wc [参数] 文件名称”。
tr tr命令用于替换文本内容中的字符,英文全称为“transform”,语法格式为“tr [原始字符] [目标字符]”。
tail tail命令用于查看纯文本文件的后N行或持续刷新文件的最新内容,语法格式为“tail [参数] 文件名称”。
head head命令用于查看纯文本文件的前N行,语法格式为“head [参数] 文件名称”。
more more命令用于查看纯文本文件(内容较多的),语法格式为“more [参数] 文件名称”。
cat cat命令用于查看纯文本文件(内容较少的),英文全称为“concatenate”,语法格式为“cat [参数] 文件名称”。
which which命令用于按照指定名称快速搜索二进制程序(命令)所对应的位置,语法格式为“which 命令名称”。
whereis whereis命令用于按照名称快速搜索二进制程序(命令)、源代码以及帮助文件所对应的位置,语法格式为“whereis 命令名称”。
locate locate命令用于按照名称快速搜索文件所对应的位置,语法格式为“locate 文件名称”。
find find命令用于按照指定条件来查找文件所对应的位置,语法格式为“find [查找范围] 寻找条件”。
tree tree命令用于以树状图的形式列出目录内容及结构,输入该命令后按回车键执行即可。
ls ls命令用于显示目录中的文件信息,英文全称为“list”,语法格式为“ls [参数] [文件名称]”。
cd cd命令用于切换当前的工作路径,英文全称为“change directory”,语法格式为“cd [参数] [目录]”。
pwd pwd命令用于显示用户当前所处的工作目录,英文全称为“print working directory”,输入该命令后按回车键执行即可。
sosreport sosreport命令用于收集系统配置及架构信息并输出诊断文档,输入该命令后按回车键执行即可。
history history命令用于显示执行过的命令历史,语法格式为“history [-c]”。
netstat netstat命令用于显示如网络连接、路由表、接口状态等的网络相关信息,英文全称为“network status”,语法格式为“netstat [参数]”。
tracepath tracepath命令用于显示数据包到达目的主机时途中经过的所有路由信息,语法格式为“tracepath [参数] 域名”。
ping ping命令用于测试主机之间的网络连通性,语法格式为“ping [参数] 主机地址”。
last last命令用于调取主机的被访记录,输入该命令后按回车键执行即可。
who who命令用于查看当前登入主机的用户终端信息,输入该命令后按回车键执行即可。
free free命令用于显示当前系统中内存的使用量信息,语法格式为“free [-h]”。
uptime uptime命令用于查看系统的负载信息,输入该命令后按回车键执行即可。
uname uname命令用于查看系统内核版本与系统架构等信息,英文全称为“unix name”,语法格式为“uname [-a]”。
ifconfig ifconfig命令用于获取网卡配置与网络状态等信息,英文全称为“interface config”,语法格式为“ifconfig [参数] [网络设备]”。
killall killall命令用于终止某个指定名称的服务所对应的全部进程,语法格式为“killall [参数] 服务名称”。
kill kill命令用于终止某个指定PID值的服务进程,语法格式为“kill [参数] 进程的PID”。
pidof pidof命令用于查询某个指定服务进程的PID号码值,语法格式为“pidof [参数] 服务名称”。
nice nice命令用于调整进程的优先级,语法格式为“nice 优先级数字 服务名称”。
top top命令用于动态地监视进程活动及系统负载等信息,输入该命令后按回车键执行即可。
pstree pstree命令用于以树状图的形式展示进程之间的关系,英文全称为“process tree”,输入该命令后按回车键执行即可。
ps ps命令用于查看系统中的进程状态,英文全称为“processes”,语法格式为“ps [参数]”。
wget wget命令用于在终端命令行中下载网络文件,英文全称为“web get”,语法格式为“wget [参数] 网址”。
poweroff poweroff命令用于关闭系统,输入该命令后按回车键执行即可。
reboot reboot命令用于重启系统,输入该命令后按回车键执行即可。
timedatectl timedatectl命令用于设置系统的时间,英文全称为“time date control”,语法格式为“timedatectl [参数]”。
date date命令用于显示或设置系统的时间与日期,语法格式为“date [+指定的格式]”。
echo echo命令用于在终端设备上输出字符串或变量提取后的值,语法格式为“echo [字符串] [$变量]”。

常用系统工作命令

1.echo命令

echo命令用于在终端设备上输出字符串或变量提取后的值,语法格式为“echo [字符串] [$变量]”。

这是Linux系统中最常用的几个命令之一,它的操作却非常简单,执行“echo字符串”或“echo $变量”就行,其中$符号的意思是提取变量的实际值,以便后续的输出操作。

2.date命令

date命令用于显示或设置系统的时间与日期,语法格式为“date [+指定的格式]”。

用户只需在强大的date命令后输入以“+”号开头的参数,即可按照指定格式来输出系统的时间或日期,这样在日常工作时便可以把备份数据的命令与指定格式输出的时间信息结合到一起。date命令中常见的参数格式及其作用如表所示。

参数 作用
%S 秒(00~59)
%M 分钟(00~59)
%H 小时(00~23)
%I 小时(00~12)
%m 月份(1~12)
%p 显示出AM或PM
%a 缩写的工作日名称(例如:Sun)
%A 完整的工作日名称(例如:Sunday)
%b 缩写的月份名称(例如:Jan)
%B 完整的月份名称(例如:January)
%q 季度(1~4)
%y 简写年份(例如:20)
%Y 完整年份(例如:2020)
%d 本月中的第几天
%j 今年中的第几天
%n 换行符(相当于按下回车键)
%t 跳格(相当于按下Tab键)

按照默认格式查看当前系统时间的date命令如下所示:

[root@localhost ~]# date
2023年 03月 21日 星期二 08:58:46 CST

按照“年-月-日 小时:分钟:秒”的格式查看当前系统时间的date命令如下所示:

[root@localhost ~]# date "+%Y-%m-%d %H:%M:%S"
2023-03-21 08:59:34

将系统的当前时间设置为2020年11月1日8点30分的date命令如下所示:

[root@localhost ~]# date -s "2023-03-21 15:16:20"
2023年 03月 21日 星期二 15:16:20 CST

date命令中的参数%j可用来查看今天是当年中的第几天。这个参数能够很好地区分备份时间的早晚,即数字越大,越靠近当前时间。该参数的使用方式以及显示结果如下所示:

[root@localhost ~]# date "+%j"
080

date命令中的参数%d可用来查看今天是当月中的第几天。该参数的使用方式以及显示结果如下所示:

[root@localhost ~]# date +%d
21

3.timedatectl命令

timedatectl命令用于设置系统的时间,英文全称为“time date control”,语法格式为“timedatectl [参数]”。

发现电脑时间跟实际时间不符?如果只差几分钟的话,我们可以直接调整。但是,如果差几个小时,那么除了调整当前的时间,还有必要检查一下时区了。timedatectl命令中常见的参数格式及作用如表所示。

参数 作用
status 显示状态信息
list-timezones 列出已知时区
set-time 设置系统时间
set-timezone 设置生效时区

查看系统时间与时区的方法如下:

[root@localhost ~]# timedatectl status
      Local time: 二 2023-03-21 09:05:14 CST
  Universal time: 二 2023-03-21 01:05:14 UTC
        RTC time: 二 2023-03-21 01:05:14
       Time zone: Asia/Shanghai (CST, +0800)
     NTP enabled: yes
NTP synchronized: yes
 RTC in local TZ: no
      DST active: n/a
[root@localhost ~]# 

如果您查到的时区不是上海(Asia/Shanghai),可以手动进行设置:

[root@linuxprobe ~]# timedatectl set-timezone Asia/Shanghai

如果时间还是不正确,可再手动修改系统日期:

[root@linuxprobe ~]# timedatectl set-time 2021-05-18

而如果想修改时间的话,也很简单:

[root@linuxprobe ~]# timedatectl set-time 9:30
[root@linuxprobe ~]# date 
Tue May 18 09:30:01 CST 2021

4.reboot命令

reboot命令用于重启系统,输入该命令后按回车键执行即可。

由于重启计算机这种操作会涉及硬件资源的管理权限,因此最好是以root管理员的身份来重启,普通用户在执行该命令时可能会被拒绝。reboot的命令如下:

[root@linuxprobe ~]# reboot

5.poweroff命令

poweroff命令用于关闭系统,输入该命令后按回车键执行即可。

与上面相同,该命令也会涉及硬件资源的管理权限,因此最好还是以root管理员的身份来关闭电脑,其命令如下:

[root@linuxprobe ~]# poweroff

6.wget命令

wget命令用于在终端命令行中下载网络文件,英文全称为“web get”,语法格式为“wget [参数] 网址”。

借助于wget命令,可以无须打开浏览器,直接在命令行界面中就能下载文件。如果您没有Linux系统的管理经验,当前只需了解一下wget命令的参数以及作用,然后看一眼下面的演示实验就够了,切记不要急于求成。下表所示为wget命令中的参数以及参数的作用。

参数 作用
-V 显示版本信息
-h 显示帮助信息
-b 后台下载模式
-O 定义本地文件名
-P 下载到指定目录
-t 最大尝试次数
-c 断点续传
-p 下载页面内所有资源,包括图片、视频等
-r 递归下载

安装最小系统下没有wget命令,需要安装wget软件包:

[root@localhost ~]# yum -y install wget
[root@localhost ~]# rpm -qa | grep wget
wget-1.14-18.el7_6.1.x86_64

 

wget命令的基本使用:

[root@localhost ~]# wget -P /root/ -O "LinuxBook" https://www.linuxprobe.com/docs/LinuxProbe.pdf
--2023-03-21 09:31:46--  https://www.linuxprobe.com/docs/LinuxProbe.pdf
正在解析主机 www.linuxprobe.com (www.linuxprobe.com)... 39.98.160.175
正在连接 www.linuxprobe.com (www.linuxprobe.com)|39.98.160.175|:443... 已连接。
已发出 HTTP 请求,正在等待回应... 200 OK
长度:23335661 (22M) [application/pdf]
正在保存至: “LinuxBook”

100%[===================================================================>] 23,335,661   415KB/s 用时 41s    

2023-03-21 09:32:28 (551 KB/s) - 已保存 “LinuxBook” [23335661/23335661])

7.ps命令

ps命令用于查看系统中的进程状态,英文全称为“processes”,语法格式为“ps [参数]”。ps命令的常见参数以及作用如表所示。

参数 作用
-a 显示所有进程(包括其他用户的进程)
-u 用户以及其他详细信息
-x 显示没有控制终端的进程

Linux系统中时刻运行着许多进程,如果能够合理地管理它们,则可以优化系统的性能。在Linux系统中有5种常见的进程状态,分别为运行、中断、不可中断、僵死与停止,其各自含义如下所示。

R(运行):进程正在运行或在运行队列中等待。

S(中断):进程处于休眠中,当某个条件形成后或者接收到信号时,则脱离该 状态。

D(不可中断):进程不响应系统异步信号,即便用kill命令也不能将其中断。

Z(僵死):进程已经终止,但进程描述符依然存在, 直到父进程调用wait4()系统函数后将进程释放。

T(停止):进程收到停止信号后停止运行。

除了上面5种常见的进程状态,还有可能是高优先级(<)、低优先级(N)、被锁进内存(L)、包含子进程(s)以及多线程(l)这5种补充形式。

当执行ps aux命令后通常会看到如表所示的进程状态。表只是列举了部分输出值,而且正常的输出值中不包括中文注释。

USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
进程的所有者 进程ID号 运算器占用率 内存占用率 虚拟内存使用量(单位是KB) 占用的固定内存量(单位是KB) 所在终端 进程状态 被启动的时间 实际使用CPU的时间 命令名称与参数
root 1 0.0 0.5 244740 10636 ? Ss 07:54 0:02 /usr/lib/systemd/ systemd --switched-root --system --deserialize 18
root 2 0.0 0.0 0 0 ? S 07:54 0:00 [kthreadd]
root 3 0.0 0.0 0 0 ? I< 07:54 0:00 [rcu_gp]
root 4 0.0 0.0 0 0 ? I< 07:54 0:00 [rcu_par_gp]
root 5 0.0 0.0 0 0 ? I< 07:54 0:00 [kworker/0:0H-kbl
root 6 0.0 0.0 0 0 ? I< 07:54 0:00 [mm_percpu_wq]
root 7 0.0 0.0 0 0 ? S 07:54 0:00 [ksoftirqd/0]
root 8 0.0 0.0 0 0 ? I 07:54 0:00 [rcu_sched]
root 9 0.0 0.0 0 0 ? S 07:54 0:00 [migration/0]
……………… 省略部分输出信息 ………………

在Linux系统中的命令参数有长短格式之分,长格式和长格式之间不能合并,长格式和短格式之间也不能合并,但短格式和短格式之间是可以合并的,合并后仅保留一个减号(-)即可。另外ps命令可允许参数不加减号(-),因此可直接写成ps aux的样子。

8.pstree命令

pstree命令用于以树状图的形式展示进程之间的关系,英文全称为“process tree”,输入该命令后按回车键执行即可

前文提到,在执行ps命令后,产生的信息量太大又没有规律,很难让人再想看第二眼。如果想让进程以树状图的形式,有层次地展示出进程之间的关系,则可以使用pstree命令:

[root@localhost ~]# pstree
systemd─┬─NetworkManager─┬─dhclient
        │                └─2*[{NetworkManager}]
        ├─auditd───{auditd}
        ├─chronyd
        ├─crond
        ├─dbus-daemon───{dbus-daemon}
        ├─firewalld───{firewalld}
        ├─login───bash
        ├─lvmetad
        ├─master─┬─pickup
        │        └─qmgr
        ├─polkitd───6*[{polkitd}]
        ├─rsyslogd───2*[{rsyslogd}]
        ├─sshd───sshd───bash───pstree
        ├─systemd-journal
        ├─systemd-logind
        ├─systemd-udevd
        └─tuned───4*[{tuned}]
[root@localhost ~]# 

 

安装最小系统下没有pstree命令,需要安装pstree软件包:

[root@localhost ~]# pstree
-bash: pstree: 未找到命令
[root@localhost ~]# yum -y install psmisc

9.top命令

top命令用于动态地监视进程活动及系统负载等信息,输入该命令后按回车键执行即可

前面介绍的命令都是静态地查看系统状态,不能实时滚动最新数据,而top命令能够动态地查看系统状态,因此完全可以将它看作是Linux中“强化版的Windows任务管理器”,top是相当好用的性能分析工具。

top - 12:44:45 up  3:37,  2 users,  load average: 0.01, 0.02, 0.05
Tasks: 100 total,   1 running,  99 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.3 sy,  0.0 ni, 99.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  1863004 total,  1236688 free,   221772 used,   404544 buff/cache
KiB Swap:  2097148 total,  2097148 free,        0 used.  1484708 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                  
  1549 root      20   0  158904   5900   4548 S  0.3  0.3   0:01.48 sshd                                     
     1 root      20   0  128028   6632   4144 S  0.0  0.4   0:00.93 systemd       
     ....................................................................

top命令执行结果的前5行为系统整体的统计信息,其所代表的含义如下。

第1行:系统时间、运行时间、登录终端数、系统负载(3个数值分别为1分钟、5分钟、15分钟内的平均值,数值越小意味着负载越低)。

第2行:进程总数、运行中的进程数、睡眠中的进程数、停止的进程数、僵死的进程数。

第3行:用户占用资源百分比、系统内核占用资源百分比、改变过优先级的进程资源百分比、空闲的资源百分比等。其中数据均为CPU数据并以百分比格式显示,例如“99.9 id”意味着有99.9%的CPU处理器资源处于空闲。

第4行:物理内存总量、内存空闲量、内存使用量、作为内核缓存的内存量。

第5行:虚拟内存总量、虚拟内存空闲量、虚拟内存使用量、已被提前加载的内存量。

10.nice命令

nice命令用于调整进程的优先级,语法格式为“nice优先级数字 服务名称”。

在top命令输出的结果中,PR和NI值代表的是进程的优先级,数字越低(取值范围是-20~19),优先级越高。在日常的生产工作中,可以将一些不重要进程的优先级调低,让紧迫的服务更多地利用CPU和内存资源,以达到合理分配系统资源的目的。例如将bash服务的优先级调整到最高:

[root@localhost ~]# nice -n -20 bash
[root@localhost ~]# 

11.pidof命令

pidof命令用于查询某个指定服务进程的PID号码值,语法格式为“pidof [参数] 服务名称”。

每个进程的进程号码值(PID)是唯一的,可以用于区分不同的进程。例如,执行如下命令来查询本机上sshd服务程序的PID:

[root@localhost ~]# nice -n -20 bash
[root@localhost ~]# pidof sshd
1549 1007
[root@localhost ~]# pidof nginx
[root@localhost ~]# pidof java
[root@localhost ~]# pidof bash
1898 1553 1532
[root@localhost ~]# 

12.kill命令

kill命令用于终止某个指定PID值的服务进程,语法格式为“kill [参数] 进程的PID”。

接下来,使用kill命令把上面用pidof命令查询到的PID所代表的进程终止掉,其命令如下所示。这种操作的效果等同于强制停止sshd服务。

[root@localhost ~]# pidof sshd
1549 1007
[root@localhost ~]# kill 1549
Session is disconnected

但有时系统会提示进程无法被终止,此时可以加参数-9,表示最高级别地强制杀死进程:

[root@localhost ~]# kill -9 1549

13.    killall命令

killall命令用于终止某个指定名称的服务所对应的全部进程,语法格式为“killall [参数] 服务名称”。

通常来讲,复杂软件的服务程序会有多个进程协同为用户提供服务,如果用kill命令逐个去结束这些进程会比较麻烦,此时可以使用killall命令来批量结束某个服务程序带有的全部进程。下面以httpd服务程序为例,来结束其全部进程。由于RHEL 8系统默认没有安装httpd服务程序,因此大家此时只需看操作过程和输出结果即可,等学习了相关内容之后再来实践。

[root@linuxprobe ~]# pidof httpd
13581 13580 13579 13578 13577 13576
[root@linuxprobe ~]# killall httpd
[root@linuxprobe ~]# pidof httpd
[root@linuxprobe ~]# 

如果有些命令在执行时不断地在屏幕上输出信息,影响到后续命令的输入,则可以在执行命令时在末尾添加一个&符号,这样命令将进入系统后台来执行。

系统状态检测命令

1.ifconfig命令

ifconfig命令用于获取网卡配置与网络状态等信息,英文全称为“interface config”,语法格式为“ifconfig [参数] [网络设备]”。

使用ifconfig命令来查看本机当前的网卡配置与网络状态等信息时,其实主要查看的就是网卡名称、inet参数后面的IP地址、ether参数后面的网卡物理地址(又称为MAC地址),以及RX、TX的接收数据包与发送数据包的个数及累计流量:

[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.0.195  netmask 255.255.255.0  broadcast 192.168.0.255
        inet6 fe80::6c43:c02f:a28f:fd0c  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:c3:ed:cd  txqueuelen 1000  (Ethernet)
        RX packets 65944  bytes 56631740 (54.0 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 52871  bytes 95196947 (90.7 MiB)
        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 68  bytes 5912 (5.7 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 68  bytes 5912 (5.7 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# 

 

安装最小系统下没有ifconfig命令,需要安装net-tools软件包:

[root@localhost ~]# ifconfig
-bash: ifconfig: 未找到命令
[root@localhost ~]# yum -y install net-tools

2.uname命令

uname命令用于查看系统内核版本与系统架构等信息,英文全称为“unix name”,语法格式为“uname [-a]”。

在使用uname命令时,一般要固定搭配上-a参数来完整地查看当前系统的内核名称、主机名、内核发行版本、节点名、压制时间、硬件名称、硬件平台、处理器类型以及操作系统名称等信息:

[root@localhost ~]# uname
Linux
[root@localhost ~]# uname -a
Linux localhost.localdomain 3.10.0-1160.el7.x86_64 #1 SMP Mon Oct 19 16:18:59 UTC 2020 x86_64 x86_64 x86_64 GNU/Linux
[root@localhost ~]# 

顺带一提,如果要查看当前系统版本的详细信息,则需要查看redhat-release文件,其命令以及相应的结果如下:

[root@localhost ~]# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
[root@localhost ~]#

3.uptime命令

uptime命令用于查看系统的负载信息,输入该命令后按回车键执行即可。

uptime命令真的很棒,它可以显示当前系统时间、系统已运行时间、启用终端数量以及平均负载值等信息。平均负载值指的是系统在最近1分钟、5分钟、15分钟内的压力情况(下面加粗的信息部分),负载值越低越好:

[root@localhost ~]# uptime
 15:39:40 up  4:03,  2 users,  load average: 0.00, 0.01, 0.05
[root@localhost ~]# 

“负载值越低越好”是对运维人员来讲的,越低表示越安全省心。但是公司购置的硬件设备如果长期处于空闲状态,则明显是种资源浪费,老板也不会开心。所以建议负载值保持在1左右,在生产环境中不要超过5就好。

每1s刷新一次系统负载情况:

[root@localhost ~]# watch -n 1 uptime

4.free命令

free命令用于显示当前系统中内存的使用量信息,语法格式为“free [-h]”。

为了保证Linux系统不会因资源耗尽而突然宕机,运维人员需要时刻关注内存的使用量。在使用free命令时,可以结合使用-h参数以更人性化的方式输出当前内存的实时使用量信息。

内存总量 已用量 空闲量 进程共享的内存量 磁盘缓存的内存量 缓存的内存量 可用量
total used free shared buffers buff/cache available

如果不使用-h(易读模式)查看内存使用量情况,则默认以KB为单位。这样一来,服务器如果有几百GB的内存,则换算下来就会是一大长串的数字,真不利于阅读。

[root@localhost ~]# free
              total        used        free      shared  buff/cache   available
Mem:        1863004      221680     1235344        9748      405980     1484692
Swap:       2097148           0     2097148
[root@localhost ~]# free -h
              total        used        free      shared  buff/cache   available
Mem:           1.8G        216M        1.2G        9.5M        396M        1.4G
Swap:          2.0G          0B        2.0G
[root@localhost ~]#

5.who命令

who命令用于查看当前登入主机的用户终端信息,输入该命令后按回车键执行即可。

这3个简单的字母可以快速显示出所有正在登录本机的用户名称以及他们正在开启的终端信息;如果有远程用户,还会显示出来访者的IP地址。

[root@localhost ~]# who
root     tty1         2023-03-21 09:07
root     pts/0        2023-03-21 15:34 (192.168.0.130)
[root@localhost ~]# 

 

登陆的用户名 终端设备 登陆到系统的时间
root tty1 2023-03-21 09:07

 

6.last命令

last命令用于调取主机的被访记录,输入该命令后按回车键执行即可。

Linux系统会将每次的登录信息都记录到日志文件中,如果哪天想翻阅了,直接执行这条命令就行:

[root@localhost ~]# last
root     pts/0        192.168.0.130    Tue Mar 21 15:34   still logged in   
root     pts/0        192.168.0.130    Tue Mar 21 09:07 - 15:22  (06:14)    
root     tty1                          Tue Mar 21 09:07   still logged in   
reboot   system boot  3.10.0-1160.el7. Tue Mar 21 09:07 - 15:47  (06:40)    
root     pts/0        192.168.0.130    Tue Mar 21 08:30 - crash  (00:36)    
root     tty1                          Tue Mar 21 08:30 - 09:06  (00:36)    
reboot   system boot  3.10.0-1160.el7. Tue Mar 21 08:29 - 15:47  (07:17)    
root     pts/0        192.168.0.130    Mon Mar 20 19:00 - crash  (13:28)    
root     pts/0        192.168.0.130    Mon Mar 20 17:13 - 19:00  (01:47)    
root     pts/0        192.168.0.130    Mon Mar 20 17:12 - 17:13  (00:00)    
root     tty1                          Mon Mar 20 17:09 - crash  (15:19)    
reboot   system boot  3.10.0-1160.el7. Mon Mar 20 17:09 - 15:47  (22:37)    

wtmp begins Mon Mar 20 17:09:33 2023
[root@localhost ~]# 

 

7.ping命令

ping命令用于测试主机之间的网络连通性,语法格式为“ping [参数] 主机地址”。

执行ping命令时,系统会使用ICMP向远端主机发出要求回应的信息,若连接远端主机的网络没有问题,远端主机会回应该信息。由此可见,ping命令可用于判断远端主机是否在线并且网络是否正常。ping命令的常见参数以及作用如表所示。

参数 作用
-c 总共发送次数
-l 指定网卡名称
-i 每次间隔时间(秒)
-W 最长等待时间(秒)
[root@localhost ~]# ping 192.168.0.195
PING 192.168.0.195 (192.168.0.195) 56(84) bytes of data.
64 bytes from 192.168.0.195: icmp_seq=1 ttl=64 time=0.054 ms
64 bytes from 192.168.0.195: icmp_seq=2 ttl=64 time=0.088 ms
64 bytes from 192.168.0.195: icmp_seq=3 ttl=64 time=0.088 ms
64 bytes from 192.168.0.195: icmp_seq=4 ttl=64 time=0.088 ms
^C
--- 192.168.0.195 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3000ms
rtt min/avg/max/mdev = 0.054/0.079/0.088/0.017 ms
[root@localhost ~]# ping www.imyjs.cn
PING www.imyjs.cn (39.96.81.50) 56(84) bytes of data.
64 bytes from 39.96.81.50 (39.96.81.50): icmp_seq=1 ttl=52 time=20.7 ms
64 bytes from 39.96.81.50 (39.96.81.50): icmp_seq=2 ttl=52 time=21.0 ms
64 bytes from 39.96.81.50 (39.96.81.50): icmp_seq=3 ttl=52 time=20.4 ms

8.tracepath命令

tracepath命令用于显示数据包到达目的主机时途中经过的所有路由信息,语法格式为“tracepath [参数] 域名”。

当两台主机之间无法正常ping通时,要考虑两台主机之间是否有错误的路由信息,导致数据被某一台设备错误地丢弃。这时便可以使用tracepath命令追踪数据包到达目的主机时途中的所有路由信息,以分析是哪台设备出了问题。下面的情况就很清晰了:

[root@localhost ~]# tracepath www.imyjs.cn
 1?: [LOCALHOST]                                         pmtu 1500
 1:  gateway                                               0.583ms 
 1:  gateway                                               0.513ms 
 2:  gateway                                               0.671ms pmtu 1480
 2:  10.242.128.1                                          2.723ms 
 3:  no reply
 4:  no reply
 5:  221.183.37.181                                       18.854ms 
 6:  221.183.49.130                                       21.765ms 
 7:  218.206.88.25                                        19.638ms 
 8:  111.13.124.53                                        21.997ms 
 9:  123.56.34.6                                          22.367ms 
10:  116.251.117.89                                       23.405ms 
11:  no reply
12:  no reply
13:  no reply
………………省略部分输出信息………………     

9.netstat命令

netstat命令用于显示如网络连接、路由表、接口状态等的网络相关信息,英文全称为“network status”,语法格式为“netstat [参数]”。

只要netstat命令使用得当,便可以查看到网络状态的方方面面信息。netstat命令的常见参数以及作用如表所示。

-a 显示所有连接中的Socket
-p 显示正在使用的Socket信息
-t 显示TCP协议的连接状态
-u 显示UDP协议的连接状态
-n 使用IP地址,不使用域名
-l 仅列出正在监听的服务状态
-i 显示网卡列表信息
-r 显示路由表信息

使用netstat命令显示详细的网络状况:

[root@localhost ~]# 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:smtp          0.0.0.0:*               LISTEN     
tcp        0     64 localhost.localdoma:ssh 192.168.0.130:50194     ESTABLISHED
tcp6       0      0 [::]:ssh                [::]:*                  LISTEN     
tcp6       0      0 localhost:smtp          [::]:*                  LISTEN     
udp        0      0 localhost:323           0.0.0.0:*                        
………………省略部分输出信息………………

使用netstat命令显示网卡列表:

[root@localhost ~]# netstat -i
Kernel Interface table
Iface             MTU    RX-OK RX-ERR RX-DRP RX-OVR    TX-OK TX-ERR TX-DRP TX-OVR Flg
ens33            1500    67797      0      0 0         54139      0      0      0 BMRU
lo              65536       76      0      0 0            76      0      0      0 LRU
[root@localhost ~]# 

10.history命令

history命令用于显示执行过的命令历史,语法格式为“history [-c]”。

history命令应该是运维人员最喜欢的命令。执行history命令能显示出当前用户在本地计算机中执行过的最近1000条命令记录。如果觉得1000不够用,可以自定义/etc/profile文件中的HISTSIZE变量值。在使用history命令时,可以使用-c参数清空所有的命令历史记录还可以使用“!编码数字”的方式来重复执行某一次的命令。总之,history命令有很多有趣的玩法等待您去开发。

历史命令会被保存到用户家目录中的.bash_history文件中。Linux系统中以点(.)开头的文件均代表隐藏文件,这些文件大多数为系统服务文件,可以用cat命令查看其文件内容:

[root@localhost ~]# pwd
/root
[root@localhost ~]# ls -a
.  ..  anaconda-ks.cfg  .bash_history  .bash_logout  .bash_profile  .bashrc  .cshrc  .lesshst  .tcshrc
[root@localhost ~]# cat .bash_history 

要清空当前用户在本机上执行的Linux命令历史记录信息,可执行如下命令:

[root@localhost ~]# history -c
[root@localhost ~]# 

11.    sosreport命令

sosreport命令用于收集系统配置及架构信息并输出诊断文档,输入该命令后按回车键执行即可。

当Linux系统出现故障需要联系技术支持人员时,大多数时候都要先使用这个命令来简单收集系统的运行状态和服务配置信息,以便让技术支持人员能够远程解决一些小问题,抑或让他们能提前了解某些复杂问题。

sosreport命令有点像是远程问诊。假如我们今天有点咳嗽发烧不舒服,可以先从网上搜索相关症状的病因,如果仅仅是感冒的话那就多喝水,这就免去了到医院挂号看病的车马劳顿;而如果怀疑出了大毛病,再请专业人员进行处理也不迟。

[root@localhost ~]# sosreport

sosreport (version 3.9)

This command will collect diagnostic and configuration information from
this CentOS Linux system and installed applications.

An archive containing the collected information will be generated in
/var/tmp/sos.8Izi56 and may be provided to a CentOS support
representative.

Any information provided to CentOS will be treated in accordance with
the published support policies at:

  https://wiki.centos.org/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.

按 ENTER 键继续,或者 CTRL-C 组合键退出。[此处按下回车键进行确认]

Please enter the case id that you are generating this report for []: [此处按下回车键进行确认]

 Setting up archive ...
 Setting up plugins ...
[plugin:firewalld] skipped command 'nft list ruleset': required kmods missing: nf_tables.  Use '--allow-system-changes' to enable collection.
[plugin:networking] skipped command 'nft list ruleset': required kmods missing: nf_tables. 
[plugin:networking] skipped command 'ip -s macsec show': required kmods missing: macsec.  Use '--allow-system-changes' to enable collection.
[plugin:networking] skipped command 'ss -peaonmi': required kmods missing: inet_diag, udp_diag, tcp_diag, netlink_diag, af_packet_diag, unix_diag.  Use '--allow-system-changes' to enable collection.
 Running plugins. Please wait ...

  Finishing plugins              [Running: processor]                                     
  Finished running plugins                                                               
生成压缩归档......

Your sosreport has been generated and saved in:
  /var/tmp/sosreport-localhost-2023-03-21-ekfxkrn.tar.xz[收集好的资料压缩文件]

 Size   8.39MiB
 Owner  root
 md5    210dcbfaa6124d827d8fc65d8a43e714

Please send this file to your support representative.

查找定位文件命令

工作目录指的是用户当前在系统中所处的位置。

1.pwd命令

pwd命令用于显示用户当前所处的工作目录,英文全称为“print working directory”,输入该命令后按回车键执行即可。

使用pwd命令查看当前所处的工作目录:

[root@localhost ~]# pwd
/root
[root@localhost ~]# 

2.cd命令

cd命令用于切换当前的工作路径,英文全称为“change directory”,语法格式为“cd [参数] [目录]”。

这个命令应该是最常用的一个Linux命令了。可以通过cd命令迅速、灵活地切换到不同的工作目录。除了常见的切换目录方式,还可以使用“cd -”命令返回到上一次所处的目录使用“cd..”命令进入上级目录,以及使用“cd~”命令切换到当前用户的家目录,抑或使用“cd~username”命令切换到其他用户的家目录。例如,使用下述的cd命令切换进/etc目录中:

[root@localhost ~]# cd /etc
[root@localhost etc]# 

同样的道理,可使用下述命令切换到/bin目录中:

[root@localhost etc]# cd ../bin/
[root@localhost bin]# 

 

此时,要返回到上一次的目录(即/etc目录),可执行如下命令:

[root@localhost bin]# cd -
/etc
[root@localhost etc]# 

 

还可以通过下面的命令快速切换到用户的家目录:

[root@localhost etc]# cd ~
[root@localhost ~]# 

3.ls命令

ls命令用于显示目录中的文件信息,英文全称为“list”,语法格式为“ls [参数] [文件名称]”。

所处的工作目录不同,当前工作目录下能看到的文件肯定也不同。使用ls命令的-a参数可以看到全部文件(包括隐藏文件)使用-l参数可以查看文件的属性、大小等详细信息。将这两个参数整合之后,再执行ls命令即可查看当前目录中的所有文件并输出这些文件的属性信息:

[root@localhost ~]# ls -al
总用量 32
dr-xr-x---.  2 root root  151 3月  21 09:36 .
dr-xr-xr-x. 17 root root  224 3月  20 17:08 ..
-rw-------.  1 root root 1241 3月  20 17:09 anaconda-ks.cfg
-rw-------.  1 root root 2620 3月  21 15:22 .bash_history
-rw-r--r--.  1 root root   18 12月 29 2013 .bash_logout
-rw-r--r--.  1 root root  176 12月 29 2013 .bash_profile
-rw-r--r--.  1 root root  176 12月 29 2013 .bashrc
-rw-r--r--.  1 root root  100 12月 29 2013 .cshrc
-rw-------.  1 root root   48 3月  21 08:51 .lesshst
-rw-r--r--.  1 root root  129 12月 29 2013 .tcshrc
[root@localhost ~]#

如果想要查看目录属性信息,则需要额外添加一个-d参数。例如,可使用如下命令查看/etc目录的权限与属性信息:

[root@localhost ~]# ls -ld /etc
drwxr-xr-x. 74 root root 8192 3月  21 16:09 /etc
[root@localhost ~]# 

4.tree命令

tree命令用于以树状图的形式列出目录内容及结构,输入该命令后按回车键执行即可。

虽然ls命令可以很便捷地查看目录内有哪些文件,但无法直观地获取到目录内文件的层次结构。比如,假如目录A中有个B,B中又有个C,那么ls命令就只能看到最外面的A目录,显然有些时候这不太够用。tree命令则能够以树状图的形式列出目录内所有文件的结构。

安装最小系统下没有tree命令,需要安装tree软件包:

[root@localhost ~]# yum -y install tree

5.find命令

find命令用于按照指定条件来查找文件所对应的位置,语法格式为“find [查找范围] 寻找条件”。

多次提到“Linux系统中的一切都是文件”,接下来就要见证这句话的分量了。在Linux系统中,搜索工作一般都是通过find命令来完成的,它可以使用不同的文件特性作为寻找条件(如文件名、大小、修改时间、权限等信息),一旦匹配成功则默认将信息显示到屏幕上。find命令的参数以及作用如表所示。

参数 作用
-name 匹配名称
-perm 匹配权限(mode为完全匹配,-mode为包含即可)
-user 匹配所有者
-group 匹配所有组
-mtime -n +n 匹配修改内容的时间(-n指n天以内,+n指n天以前)
-atime -n +n 匹配访问文件的时间(-n指n天以内,+n指n天以前)
-ctime -n +n 匹配修改文件权限的时间(-n指n天以内,+n指n天以前)
-nouser 匹配无所有者的文件
-nogroup 匹配无所有组的文件
-newer f1 !f2 匹配比文件f1新但比f2旧的文件
-type b/d/c/p/l/f 匹配文件类型(后面的字幕字母依次表示块设备、目录、字符设备、管道、链接文件、文本文件)
-size 匹配文件的大小(+50KB为查找超过50KB的文件,而-50KB为查找小于50KB的文件)
-prune 忽略某个目录
-exec …… {}\; 后面可跟用于进一步处理搜索结果的命令

 

根据文件系统层次标准(Filesystem Hierarchy Standard)协议,Linux系统中的配置文件会保存到/etc目录中。如果要想获取该目录中所有以host开头的文件列表,可以执行如下命令:

[root@localhost ~]# find /etc -name "host*" -print
/etc/host.conf
/etc/hosts
/etc/hosts.allow
/etc/hosts.deny
/etc/selinux/targeted/active/modules/100/hostname
/etc/hostname
[root@localhost ~]# find /etc -name "host*"
/etc/host.conf
/etc/hosts
/etc/hosts.allow
/etc/hosts.deny
/etc/selinux/targeted/active/modules/100/hostname
/etc/hostname
[root@localhost ~]#

如果要在整个系统中搜索权限中包括SUID权限的所有文件,只需使用-4000即可:

[root@localhost ~]# find / -perm -4000
find: ‘/proc/12365/task/12365/fd/6’: 没有那个文件或目录
find: ‘/proc/12365/task/12365/fdinfo/6’: 没有那个文件或目录
find: ‘/proc/12365/fd/5’: 没有那个文件或目录
find: ‘/proc/12365/fdinfo/5’: 没有那个文件或目录
/usr/bin/chfn
/usr/bin/chsh
/usr/bin/chage
/usr/bin/gpasswd
/usr/bin/newgrp
/usr/bin/mount
/usr/bin/su
/usr/bin/sudo
/usr/bin/umount
/usr/bin/pkexec
/usr/bin/crontab
/usr/bin/passwd
/usr/sbin/unix_chkpwd
/usr/sbin/pam_timestamp_check
/usr/sbin/usernetctl
/usr/lib/polkit-1/polkit-agent-helper-1
/usr/libexec/dbus-1/dbus-daemon-launch-helper

 

这里需要重点讲解-exec参数的重要作用。这个参数用于把find命令搜索到的结果交由紧随其后的命令作进一步处理。它十分类似于管道符技术,并且由于find命令对参数有特殊要求,因此虽然exec是长格式形式,但它的前面依然只需要一个减号(-)。

在整个文件系统中找出所有归属于admin用户的文件并复制到/root/findresults目录中。
该实验的重点是“-exec {} \;”参数,其中的{}表示find命令搜索出的每一个文件,并且命令的结尾必须是“\;”。完成该实验的具体命令如下:

[root@localhost ~]# find / -user admin -exec cp -a {} /root/findresults/ \;
find: 用户名 ‘admin’ 未知
[root@localhost ~]# 

6.locate命令

locate命令用于按照名称快速搜索文件所对应的位置,语法格式为“locate 文件名称”。

使用find命令进行全盘搜索虽然更准确,但是效率有点低。如果仅仅是想找一些常见的且又知道大概名称的文件,不如试试locate命令。在使用locate命令时,先使用updatedb命令生成一个索引库文件,这个库文件的名字是/var/lib/mlocate/mlocate.db,后续在使用locate命令搜索文件时就是在该库中进行查找操作,速度会快很多

第一次使用locate命令之前,记得先执行updatedb命令来生成索引数据库,然后再进行查找:

[root@localhost mlocate]# ls
[root@localhost mlocate]# updatedb
[root@localhost mlocate]# ls
mlocate.db
[root@localhost mlocate]# 

使用locate命令搜索出所有包含“whereis”名称的文件所在的位置:

[root@localhost mlocate]# locate whereis
/usr/bin/whereis
/usr/share/bash-completion/completions/whereis
/usr/share/man/man1/whereis.1.gz
[root@localhost mlocate]# 

安装最小系统下没有updatedb命令,需要安装mlocate软件包:

[root@localhost ~]# updatedb
-bash: updatedb: 未找到命令
[root@localhost ~]# yum -y install mlocate

7.    whereis命令

whereis命令用于按照名称快速搜索二进制程序(命令)、源代码以及帮助文件所对应的位置,语法格式为“whereis 命令名称”。

简单来说,whereis命令也是基于updatedb命令所生成的索引库文件进行搜索,它与locate命令的区别是不关心那些相同名称的文件,仅仅是快速找到对应的命令文件及其帮助文件所在的位置。

下面使用whereis命令分别查找出ls和pwd命令所在的位置:

[root@localhost mlocate]# whereis ls
ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz
[root@localhost mlocate]# whereis pwd
pwd: /usr/bin/pwd /usr/share/man/man1/pwd.1.gz
[root@localhost mlocate]# 

8.    which命令

which命令用于按照指定名称快速搜索二进制程序(命令)所对应的位置,语法格式为“which 命令名称”。

which命令是在PATH变量所指定的路径中,按照指定条件搜索命令所在的路径。也就是说,如果我们既不关心同名文件(find与locate),也不关心命令所对应的源代码和帮助文件(whereis),仅仅是想找到命令本身所在的路径,那么这个which命令就太合适了。下面查找一下locate和whereis命令所对应的路径:

[root@localhost mlocate]# which locate
/usr/bin/locate
[root@localhost mlocate]# which whereis
/usr/bin/whereis
[root@localhost mlocate]# 

文本文件编辑命令

在Linux系统中,一切都是文件,对服务程序进行配置自然也就是编辑程序的配置文件。如果不能熟练地查阅系统或服务的配置文件,那以后工作时可就真的要尴尬了。

1.cat命令

cat命令用于查看纯文本文件(内容较少的),英文全称为“concatenate”,语法格式为“cat [参数] 文件名称”。

Linux系统中有多个用于查看文本内容的命令,每个命令都有自己的特点,比如这个cat命令就是用于查看内容较少的纯文本文件

如果在查看文本内容时还想顺便显示行号的话,不妨在cat命令后面追加一个-n参数:

[root@localhost mlocate]# cat -n /etc/profile
     1  # /etc/profile
     2
     3  # System wide environment and startup programs, for login setup
     4  # Functions and aliases go in /etc/bashrc
     5
     6  # It's NOT a good idea to change this file unless you know what you
     7  # are doing. It's much better to create a custom.sh shell script in
     .....

 

2.more命令

more命令用于查看纯文本文件(内容较多的),语法格式为“more [参数] 文件名称”。

如果需要阅读长篇小说或者非常长的配置文件,那么“小cat”可就真的不适合了。因为一旦使用cat命令阅读长篇的文本内容,信息就会在屏幕上快速翻滚,导致自己还没有来得及看到,内容就已经翻篇了。因此对于长篇的文本内容,推荐使用more命令来查看。more命令会在最下面使用百分比的形式来提示您已经阅读了多少内容;还可以使用空格键或回车键向下翻页

[root@localhost ~]# more anaconda-ks.cfg 
#version=DEVEL
# System authorization information
auth --enableshadow --passalgo=sha512
.....
--More--(41%)

 

3.head命令

head命令用于查看纯文本文件的前N行,语法格式为“head [参数] 文件名称”。将每个文件的前10行打印为标准输出。

在阅读文本内容时,谁也难以保证会按照从头到尾的顺序往下看完整个文件。如果只想查看文本中前10行的内容,该怎么办呢?head命令就能派上用场了:

[root@localhost ~]# head num.txt 
1
2
3
4
5
6
7
8
9
10

指定打印行数的内容:

[root@localhost ~]# head -n 3 num.txt 
1
2
3
[root@localhost ~]#

 

4.tail命令

tail命令用于查看纯文本文件的后N行持续刷新文件的最新内容,语法格式为“tail [参数] 文件名称”。

我们可能还会遇到另外一种情况,比如需要查看文本内容的最后10行,这时就需要用到tail命令了。tail命令的操作方法与head命令非常相似,只需要执行“tail -n 20文件名称”命令就可以达到这样的效果:

[root@localhost ~]# tail -n 20 num.txt 
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38

[root@localhost ~]# 

tail命令最强悍的功能是能够持续刷新一个文件的内容,当想要实时查看最新的日志文件时,这特别有用,此时的命令格式为“tail -f文件名称”:

[root@localhost ~]# tail -f /var/log/messages
Mar 21 17:53:49 localhost chronyd[662]: Source 202.112.29.82 replaced with 84.16.73.33
Mar 21 17:59:18 localhost chronyd[662]: Selected source 119.28.183.184
Mar 21 18:00:01 localhost chronyd[662]: Can't synchronise: no majority
Mar 21 18:01:01 localhost systemd: Started Session 10 of user root.
Mar 21 18:04:40 localhost chronyd[662]: Selected source 202.118.1.81
Mar 21 18:04:40 localhost chronyd[662]: System clock wrong by 48419.241449 seconds, adjustment started
Mar 21 18:28:32 localhost systemd: Started Session 11 of user root.
Mar 21 18:28:32 localhost systemd-logind: New session 11 of user root.
Mar 21 18:56:35 localhost yum[12826]: Installed: mlocate-0.26-8.el7.x86_64
Mar 21 19:01:01 localhost systemd: Started Session 12 of user root.

 

5.tr命令

tr命令用于替换文本内容中的字符,英文全称为“transform”,语法格式为“tr [原始字符] [目标字符]”。

在很多时候,我们想要快速地替换文本中的一些词汇,又或者想把整个文本内容都进行替换。如果进行手工替换,难免工作量太大,尤其是需要处理大批量的内容时,进行手工替换更是不现实。这时,就可以先使用cat命令读取待处理的文本,然后通过管道符把这些文本内容传递给tr命令进行替换操作即可。例如,把某个文本内容中的英文全部替换为大写:

[root@localhost ~]# cat anaconda-ks.cfg | tr [a-z] [A-Z]
#VERSION=DEVEL
# SYSTEM AUTHORIZATION INFORMATION
AUTH --ENABLESHADOW --PASSALGO=SHA512
# USE CDROM INSTALLATION MEDIA
CDROM
.....

6.wc命令

wc命令用于统计指定文本文件的行数、字数或字节数,英文全称为“word counts”,语法格式为“wc [参数] 文件名称”。

wc命令用于统计文本的行数、字数、字节数等。wc的参数以及相应的作用如表所示:

参数 作用
-l 只显示行数
-w 只显示单词数
-c 只显示字节数

 

在Linux系统中,/etc/passwd是用于保存所有用户信息的文件,要统计当前系统中有多少个用户,可以使用下面的命令来进行查询,是不是很神奇:

[root@localhost ~]# wc -l /etc/passwd
19 /etc/passwd
[root@localhost ~]#

7.stat命令

stat命令用于查看文件的具体存储细节和时间等信息,英文全称为“status”,语法格式为“stat 文件名称”。

大家都知道,文件有一个修改时间。其实,除了修改时间之外,Linux系统中的文件包含3种时间状态,分别是Access Time(内容最后一次被访问的时间,简称为Atime),Modify Time(内容最后一次被修改的时间,简称为Mtime)以及Change Time(文件属性最后一次被修改的时间,简称为Ctime)。

下面使用stat命令查看文件的这3种时间状态信息:

[root@localhost ~]# stat num.txt 
  文件:"num.txt"
  大小:106             块:8          IO 块:4096   普通文件
设备:fd00h/64768d      Inode:33588165    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
环境:unconfined_u:object_r:admin_home_t:s0
最近访问:2023-03-21 19:11:53.000838621 +0800
最近更改:2023-03-21 19:11:48.601394645 +0800
最近改动:2023-03-21 19:11:48.607894685 +0800
创建时间:-
[root@localhost ~]# 

 

8.grep命令

grep命令用于按行提取文本内容,语法格式为“grep [参数] 文件名称”。

grep命令是用途最广泛的文本搜索匹配工具。它虽然有很多参数,但是大多数基本上都用不到。有鉴于此,我们在这里只讲grep命令两个最常用的参数:

-n 参数用来显示搜索到的信息的行号;

-v 参数用于反选信息(即没有包含关键词的所有信息行)。

这两个参数几乎能完成您日后80%的工作需要,至于其他上百个参数,即使以后在工作期间遇到了,再使用man grep命令查询也来得及。grep命令的参数及其作用如表所示。

参数 作用
-b 将可执行文件(binary)当作文本文件(text)来搜索
-c 仅显示找到的行数
-i 忽略大小写
-n 显示行号
-v 反向选择——仅列出没有“关键词”的行。

在Linux系统中,/etc/passwd文件保存着所有的用户信息,而一旦用户的登录终端被设置成/sbin/nologin,则不再允许登录系统,因此可以使用grep命令查找出当前系统中不允许登录系统的所有用户的信息:

[root@localhost ~]# cat /etc/passwd | grep /sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
[root@localhost ~]# 

9.cut命令

cut命令用于按“列”提取文本内容,语法格式为“cut [参数] 文件名称”。

系统文件在保存用户数据信息时,每一项值之间是采用冒号来间隔的,先查看一下:

[root@localhost ~]# head -n 2 /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[root@localhost ~]# 

一般而言,按基于“行”的方式来提取数据是比较简单的,只需要设置好要搜索的关键词即可。但是如果按“列”搜索,不仅要使用-f参数设置需要查看的列数,还需要使用-d参数来设置间隔符号。

接下来使用下述命令尝试提取出passwd文件中的用户名信息,即提取以冒号(:)为间隔符号的第一列内容:

[root@localhost ~]# cut -d : -f 1 /etc/passwd
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-network
dbus
polkitd
sshd
postfix
chrony
[root@localhost ~]#

 

10.diff命令

diff命令用于比较多个文件之间内容的差异,英文全称为“different”,语法格式为“diff [参数] 文件名称A 文件名称B”。

在使用diff命令时,不仅可以使用--brief参数来确认两个文件是否相同,还可以使用-c参数来详细比较出多个文件的差异之处。这绝对是判断文件是否被篡改的有力神器。例如,先使用cat命令分别查看A.txt和B.txt文件的内容,然后进行比较:

[root@localhost ~]# cat A.txt 
MY WEBSITE URL IS WWW.IMYJS.CN
WELCOME TO WWW.IMYJS.CN
[root@localhost ~]# cat B.txt 
MY WEBSITE URL IS WWW.IMYJS.CN
MY PHONE NUMBER IS 15936788888
WELCOME TO CHINA~
[root@localhost ~]# 

接下来使用diff --brief命令显示比较后的结果,判断文件是否相同:

[root@localhost ~]# diff --brief A.txt B.txt 
文件 A.txt 和 B.txt 不同
[root@localhost ~]#

最后使用带有-c参数的diff命令来描述文件内容具体的不同:

[root@localhost ~]# diff --brief -c A.txt B.txt 
文件 A.txt 和 B.txt 不同
[root@localhost ~]# diff -c A.txt B.txt 
*** A.txt       2023-03-21 21:03:40.202571944 +0800
--- B.txt       2023-03-21 21:04:56.825037787 +0800
***************
*** 1,2 ****
  MY WEBSITE URL IS WWW.IMYJS.CN
! WELCOME TO WWW.IMYJS.CN
--- 1,3 ----
  MY WEBSITE URL IS WWW.IMYJS.CN
! MY PHONE NUMBER IS 15936788888
! WELCOME TO CHINA~
[root@localhost ~]# 

 

11.uniq命令

uniq命令用于去除文本中连续的重复行,英文全称为“unique”,语法格式为“uniq [参数] 文件名称”。

由uniq命令的英文全称unique(独特的,唯一的)可知,该命令的作用是用来去除文本文件中连续的重复行,中间不能夹杂其他文本行(非相邻的默认不会去重)—去除了重复的,保留的都是唯一的,自然也就是“独特的”“唯一的”了。

我们使用uniq命令对两个文本内容进行操作,区别一目了然:

[root@localhost ~]# vi uniq.txt
[root@localhost ~]# cat uniq.txt 
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
====================
welcome www.imyjs.cn
////////////////////
12345679
[root@localhost ~]# uniq uniq.txt 
welcome www.imyjs.cn
====================
welcome www.imyjs.cn
////////////////////
12345679
[root@localhost ~]# cat uniq.txt 
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
welcome www.imyjs.cn
====================
welcome www.imyjs.cn
////////////////////
12345679
[root@localhost ~]# 

 

12.sort命令

sort命令用于对文本内容进行再排序,语法格式为“sort [参数] 文件名称”。

有时文本中的内容顺序不正确,一行行地手动修改实在太麻烦了。此时使用sort命令就再合适不过了,它能够对文本内容进行再次排序。这个命令千万不能只讲理论,一定要借助于实战让大家一看就懂。sort命令的参数及其作用如表所示。

参数 作用
-f 忽略大小写
-b 忽略缩进与空格
-n 以数值型排序
-r 反向排序
-u 去除重复行
-t 指定间隔符
-k 设置字段范围

 

首先,在执行sort命令后默认会按照字母顺序进行排序,非常方便:

[root@localhost ~]# vi sort.txt
[root@localhost ~]# cat sort.txt 
banana
pear
apple
orange
raspaberry
[root@localhost ~]# sort sort.txt 
apple
banana
orange
pear
raspaberry
[root@localhost ~]# 

此外,与uniq命令不同,sort命令是无论内容行之间是否夹杂有其他内容,只要有两个一模一样的内容行,立马就可以使用-u参数进行去重操作

[root@localhost ~]# sort -u uniq.txt 
====================
////////////////////
12345679
welcome www.imyjs.cn
[root@localhost ~]# 

想对数字进行排序?一点问题都没有,而且完全不用担心出现1大于20这种问题(因为有些命令只比较数字的第一位,忽略了十、百、千的位):

[root@localhost ~]# sort -n random.txt 
3
9
12
24
45
56
67
82
98
[root@localhost ~]#

最后,我们挑战一个“高难度”的小实验。下面的内容节选自/etc/passwd文件中的前5个字段,并且进行了混乱排序。

[root@localhost ~]# vi user.txt
[root@localhost ~]# cat user.txt 
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon
polkitd:x:998:996:User for polkitd
geoclue:x:997:995:User for geoclue
rtkit:x:172:172:RealtimeKit
pulse:x:171:171:PulseAudio System Daemon
qemu:x:107:107:qemu user
usbmuxd:x:113:113:usbmuxd user
unbound:x:996:991:Unbound DNS resolver
rpc:x:32:32:Rpcbind Daemon
gluster:x:995:990:GlusterFS daemons
[root@localhost ~]# 

不难看出,上面其实是5个字段,各个字段之间是用了冒号进行间隔,如果想以第3个字段中的数字作为排序依据,那么可以用-t参数指定间隔符,用-k参数指定第几列,用-n参数进行数字排序来搞定

[root@localhost ~]# sort -t : -k 3 -n user.txt 
rpc:x:32:32:Rpcbind Daemon
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon
qemu:x:107:107:qemu user
usbmuxd:x:113:113:usbmuxd user
pulse:x:171:171:PulseAudio System Daemon
rtkit:x:172:172:RealtimeKit
gluster:x:995:990:GlusterFS daemons
unbound:x:996:991:Unbound DNS resolver
geoclue:x:997:995:User for geoclue
polkitd:x:998:996:User for polkitd
[root@localhost ~]# 

文件目录管理命令

1.touch命令

touch命令用于创建空白文件或设置文件的时间,语法格式为“touch [参数] 文件名称”。

在创建空白的文本文件方面,这个touch命令相当简洁,简洁到没有必要铺开去讲。比如,touch linuxprobe命令可以创建出一个名为linuxprobe的空白文本文件。对touch命令来讲,有难度的操作主要是体现在设置文件内容的修改时间(Mtime)、文件权限或属性的更改时间(Ctime)与文件的访问时间(Atime)上面。touch命令的参数及其作用如表所示。

参数 作用
-a 仅修改“读取时间”(atime)
-m 仅修改“修改时间”(mtime)
-d 同时修改atime与mtime

接下来,先使用ls命令查看一个文件的修改时间,随后修改这个文件,最后再查看一下文件的修改时间,看是否发生了变化:

[root@localhost ~]# ls -l A.txt 
-rw-r--r--. 1 root root 55 3月  21 21:03 A.txt
[root@localhost ~]# echo modify file content >> A.txt 
[root@localhost ~]# cat A.txt 
MY WEBSITE URL IS WWW.IMYJS.CN
WELCOME TO WWW.IMYJS.CN
modify file content
[root@localhost ~]# ls -l A.txt 
-rw-r--r--. 1 root root 75 3月  21 22:00 A.txt
[root@localhost ~]# 

如果不想让别人知道我们修改了它,那么这时就可以用touch命令把修改后的文件时间设置成修改之前的时间(很多黑客就是这样做的呢):

[root@localhost ~]# touch -d "2023-03-22 15:30" A.txt 
[root@localhost ~]# ls -l A.txt 
-rw-r--r--. 1 root root 75 3月  22 2023 A.txt
[root@localhost ~]# 

2.mkdir命令

mkdir命令用于创建空白的目录,英文全称为“make directory”,语法格式为“mkdir [参数] 目录名称”。

除了能创建单个空白目录外,mkdir命令还可以结合-p参数来递归创建出具有嵌套层叠关系的文件目录

[root@localhost ~]# mkdir imyjs
[root@localhost ~]# mkdir -p imyjs/a/b/c
[root@localhost ~]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  num.txt  random.txt  sort.txt  uniq.txt  user.txt
[root@localhost ~]# tree
.
├── anaconda-ks.cfg
├── A.txt
├── B.txt
├── imyjs
│   └── a
│       └── b
│           └── c
├── num.txt
├── random.txt
├── sort.txt
├── uniq.txt
└── user.txt

4 directories, 8 files
[root@localhost ~]# 

3.cp命令

cp命令用于复制文件或目录,英文全称为“copy”,语法格式为“cp [参数] 源文件名称 目标文件名称”。

大家对文件复制操作应该不陌生,几乎每天都会使用到。在Linux系统中,复制操作具体分为3种情况:

如果目标文件是目录,则会把源文件复制到该目录中;

如果目标文件也是普通文件,则会询问是否要覆盖它;

如果目标文件不存在,则执行正常的复制操作。

复制命令基本不会出错,唯一需要记住的就是在复制目录时要加上-r参数。cp命令的参数及其作用如表所示。

参数 作用
-p 保留原始文件的属性
-d 若对象为“链接文件”,则保留该“链接文件”的属性
-r 递归持续复制(用于目录)
-i 若目标文件存在则询问是否覆盖
-a 相当于-pdr(p、d、r为上述参数)

 

接下来,使用touch命令创建一个名为install.log的普通空白文件,然后将其复制为一份名为x.log的备份文件,最后再使用ls命令查看目录中的文件:

[root@localhost ~]# touch install.log
[root@localhost ~]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  install.log  num.txt  random.txt  sort.txt  uniq.txt  user.txt
[root@localhost ~]# cp install.log x.log
[root@localhost ~]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  install.log  num.txt  random.txt  sort.txt  uniq.txt  user.txt  x.log
[root@localhost ~]# 

4.mv命令

mv命令用于剪切或重命名文件,英文全称为“move”,语法格式为“mv [参数] 源文件名称 目标文件名称”。

剪切操作不同于复制操作,因为它默认会把源文件删除,只保留剪切后的文件如果在同一个目录中将某个文件剪切后还粘贴到当前目录下,其实也就是对该文件进行了重命名操作

[root@localhost ~]# mv x.log linux.log
[root@localhost ~]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  install.log  linux.log  num.txt  random.txt  sort.txt  uniq.txt  user.txt
[root@localhost ~]# 

5.rm命令

rm命令用于删除文件或目录,英文全称为“remove”,语法格式为“rm [参数] 文件 名称”。

在Linux系统中删除文件时,系统会默认向您询问是否要执行删除操作,如果不想总是看到这种反复的确认信息,可在rm命令后跟上-f参数来强制删除。另外,要想删除一个目录,需要在rm命令后面加一个-r参数才可以,否则删除不掉。rm命令的参数及其作用如表所示。

参数 作用
-f 强制执行
-i 删除前询问
-r 删除目录
-v 显示过程

 

下面尝试删除前面创建的install.log和linux.log文件,大家感受一下加与不加-f参数的区别:

[root@localhost ~]# rm install.log 
rm:是否删除普通空文件 "install.log"?Y 
[root@localhost ~]# rm -rf linux.log 
[root@localhost ~]# 

 

 

6.dd命令

dd命令用于按照指定大小和个数的数据块来复制文件或转换文件,语法格式为“dd if=参数值of=参数值count=参数值bs=参数值”。

dd命令是一个比较重要而且比较有特色的命令,它能够让用户按照指定大小和个数的数据块来复制文件的内容。当然,如果愿意的话,还可以在复制过程中转换其中的数据Linux系统中有一个名为/dev/zero的设备文件,每次在课堂上解释它时都充满哲学理论的色彩。因为这个文件不会占用系统存储空间,但却可以提供无穷无尽的数据,因此常常使用它作为dd命令的输入文件,来生成一个指定大小的文件。dd命令的参数及其作用如表所示。

参数 作用
if 输入的文件名称
of 输出的文件名称
bs 设置每个“块”的大小
count 设置要复制“块”的个数

 

例如,用dd命令从/dev/zero设备文件中取出一个大小为560MB的数据块,然后保存成名为560_file的文件。在理解了这个命令后,以后就能随意创建任意大小的文件了:

[root@localhost ~]# dd if=/dev/zero of=560_file count=1 bs=560M
记录了1+0 的读入
记录了1+0 的写出
587202560字节(587 MB)已复制,8.6151 秒,68.2 MB/秒
[root@localhost ~]# 

dd命令的功能也绝不仅限于复制文件这么简单。如果想把光驱设备中的光盘制作成iso格式的镜像文件,在Windows系统中需要借助于第三方软件才能做到,但在Linux系统中可以直接使用dd命令来压制出光盘镜像文件,将它变成一个可立即使用的iso镜像

[root@linuxprobe ~]# dd if=/dev/cdrom of=RHEL-server-8.0-x86_64-LinuxProbe.Com.iso
13873152+0 records in
13873152+0 records out
7103053824 bytes (7.1 GB, 6.6 GiB) copied, 27.8812 s, 255 MB/s

7.file命令

file命令用于查看文件的类型,语法格式为“file 文件名称”。

在Linux系统中,由于文本、目录、设备等所有这些一切都统称为文件,但是它们又不像Windows系统那样都有后缀,因此很难通过文件名一眼判断出具体的文件类型,这时就需要使用file命令来查看文件类型了。

[root@localhost dev]# file agpgart 
agpgart: character special
[root@localhost dev]# file rtc
rtc: symbolic link to `rtc0'
[root@localhost dev]# file dri
dri: directory
[root@localhost dev]# 

 

8.tar命令

tar命令用于对文件进行打包压缩或解压,语法格式为“tar 参数 文件名称”。

在网络上,人们越来越倾向于传输压缩格式的文件,原因是压缩文件的体积小,在网速相同的情况下,体积越小则传输时间越短。在Linux系统中,主要使用的是.tar、.tar.gz或.tar.bz2格式,大家不用担心格式太多而记不住,其实这些格式大部分都是由tar命令生成的。tar命令的参数及其作用如表所示。

参数 作用
-c 创建压缩文件
-x 解开压缩文件
-t 查看压缩包内有哪些文件
-z 用Gzip压缩或解压
-j 用bzip2压缩或解压
-v 显示压缩或解压的过程
-f 目标文件名
-p 保留原始的权限与属性
-P 使用绝对路径来压缩
-C 指定解压到的目录

首先,-c参数用于创建压缩文件,-x参数用于解压文件,因此这两个参数不能同时使用。

其次,-z参数指定使用gzip格式来压缩或解压文件-j参数指定使用bzip2格式来压缩或解压文件。用户使用时则是根据文件的后缀来决定应使用何种格式的参数进行解压。

在执行某些压缩或解压操作时,可能需要花费数个小时,如果屏幕一直没有输出,您一方面不好判断打包的进度情况,另一方面也会怀疑电脑死机了,因此非常推荐使用-v参数向用户不断显示压缩或解压的过程

-C参数用于指定要解压到哪个指定的目录

-f参数特别重要,它必须放到参数的最后一位,代表要压缩或解压的软件包名称

一般使用“tar -czvf 压缩包名称.tar.gz 要打包的目录”命令把指定的文件进行打包压缩;

相应的解压命令为“tar -xzvf 压缩包名称.tar.gz”。

下面我们逐个演示打包压缩与解压的操作,先使用tar命令把/root目录通过gzip格式进行打包压缩,并把文件命名为root.tar.gz:

[root@localhost ~]# tar -czvf root.tar.gz /root/
tar: 从成员名中删除开头的“/”
/root/
/root/.bash_logout
/root/.bash_profile
/root/.bashrc
/root/.cshrc
/root/.tcshrc
/root/anaconda-ks.cfg
/root/.lesshst
/root/.bash_history
/root/num.txt
/root/A.txt
/root/B.txt
/root/uniq.txt
/root/sort.txt
/root/random.txt
/root/user.txt
/root/imyjs/
/root/imyjs/a/
/root/imyjs/a/b/
/root/imyjs/a/b/c/
tar: /root: 在我们读入文件时文件发生了变化
[root@localhost ~]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  num.txt  random.txt  root.tar.gz  sort.txt  uniq.txt  user.txt
[root@localhost ~]# 

 

[root@localhost tar]# ls
root.tar.gz
[root@localhost tar]# tar -xzvf root.tar.gz 
root/
root/.bash_logout
root/.bash_profile
root/.bashrc
root/.cshrc
root/.tcshrc
root/anaconda-ks.cfg
root/.lesshst
root/.bash_history
root/num.txt
root/A.txt
tar: root/A.txt:时间戳 2023-03-22 15:30:00 是未来的 61250.29772299 秒之后
root/B.txt
root/uniq.txt
root/sort.txt
root/random.txt
root/user.txt
root/imyjs/
root/imyjs/a/
root/imyjs/a/b/
root/imyjs/a/b/c/
[root@localhost tar]# ls
root  root.tar.gz
[root@localhost tar]# cd root
[root@localhost root]# ls
anaconda-ks.cfg  A.txt  B.txt  imyjs  num.txt  random.txt  sort.txt  uniq.txt  user.txt
[root@localhost root]# 

 

1.在RHEL 8及众多的Linux系统中,最常使用的Shell终端是什么?

答:Bash(Bourne-Again SHell)解释器。

2.执行Linux系统命令时,添加参数的目的是什么?

答:为了让Linux系统命令能够更贴合用户的实际需求进行工作。

3.Linux系统命令、命令参数及命令对象之间,应该使用什么来间隔?

答:应该使用一个或多个空格进行间隔。

4.请写出用echo命令把SHELL变量值输出到屏幕终端的命令。

答:echo $SHELL。

5.简述Linux系统中5种进程的名称及含义。

答:在Linux系统中,有下面5种进程名称。

R(运行):进程正在运行或在运行队列中等待。

S(中断):进程处于休眠中,当某个条件形成后或者接收到信号时,则脱离该状态。

D(不可中断):进程不响应系统异步信号,即便用kill命令也不能将其中断。

Z(僵死):进程已经终止,但进程描述符依然存在, 直到父进程调用wait4()系统函数后将进程释放。

T(停止):进程收到停止信号后停止运行。

6.请尝试使用Linux系统命令关闭PID为5529的服务进程。

答:执行kill 5529命令即可;若知道服务的名称,则可以使用killall命令进行关闭。

7.使用ifconfig命令查看网络状态信息时,需要重点查看的4项信息分别是什么?

答:这4项重要的信息分别是网卡名称、IP地址、网卡物理地址以及RX/TX的收发流量数据大小。

8.使用uptime命令查看系统负载时,对应的负载数值如果是0.91、0.56、0.32,那么最近15分钟内负载压力最大的是哪个时间段?

答:通过负载数值可以看出,最近1分钟内的负载压力是最大的。

9.使用history命令查看历史命令的执行记录时,命令前面的编码数字除了排序外还有什么用处?

答:还可以用“!编码数字”的命令格式重复执行某一次的命令记录,从而避免了重复输入较长命令的麻烦。

10.若想查看的文件具有较长的内容,那么使用cat、more、head、tail中的哪个命令最合适?

答:文件内容较长,使用more命令;反之使用cat命令。

11.在使用mkdir命令创建有嵌套关系的目录时,应该加上什么参数呢?

答:应该加上-p递归迭代参数,从而自动化地创建有嵌套关系的目录。

12.在使用rm命令删除文件或目录时,可使用哪个参数来避免二次确认呢?

答:可使用-f参数,这样即可无须二次确认。

13.若有一个名为backup.tar.gz的压缩包文件,那么解压的命令应该是什么?

答:应该用tar命令进行解压,执行tar -xzvf backup.tar.gz命令即可。

14.使用grep命令对某个文件进行关键词搜索时,若想要进行文件内容反选,应使用什么参数?

答:可使用-v参数来进行匹配内容的反向选择,即显示出不包含某个关键词的行。

阅读剩余
THE END