第 7 章 常用基本命令(重要)Shell命令
Shell 可以看作是一个命令解释器,为我们提供了交互式的文本控制台界面。我们可以通过终端控制台来输入命令,由 shell 进行解释并最终交给内核执行。本章就将分类介绍常用的基本 shell 命令。
7.1 帮助命令
7.1.1 man 获得帮助信息 (manual 手册,说明书)
语法
man [命令或配置文件]
操作后显示说明
信息 | 功能 |
---|---|
NAME | 命令的名称和单行描述 |
SYNOPSIS | 怎样使用命令 |
DESCRIPTION | 命令功能的深入讨论 |
EXAMPLES | 怎样使用命令的例子 |
SEE ALSO | 相关主题(通常是手册页) |
操作方法
输入 man ls 查看 ls 命令的帮助信息
f上翻页 b或空格下翻页 q退出
7.1.2 help 获得 shell 内置命令的帮助信息
一部分基础功能的系统命令是直接内嵌在 shell 中的,系统加载启动之后会随着shell 一起加载,常驻系统内存中。这部分命令被称为“内置(built-in)命令”;相应的其它命令被称为“外部命令”。
语法
help 命令
操作方法
输入 help cd 查看 cd 命令的帮助信息 (一般不用)
输入 ls --help 查看帮助信息 (前提是外部命令)
7.1.3 终端常用快捷键
终端常用快捷键 | 功能 |
---|---|
ctrl + c | 停止进程 |
ctrl+l | 清屏,等同于 clear;彻底清屏是:reset |
tab 键 | 提示 |
上下键 | 查找执行过的命令 |
7.2 文件目录类
7.2.1 pwd 显示当前工作目录的绝对路径
pwd:print working directory 打印工作目录
语法
pwd
操作
输入 pwd
7.2.2 ls 列出目录的内容
ls全称list
语法
ls [选项] [目录或是文件]
选项说明
-a 全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
-l 长数据串列出,包含文件的属性与权限等等数据;(常用)等价于“ll”
显示说明
每行列出的信息依次是:
文件类型与权限 -> 链接数 -> 文件属主 -> 文件属组文件大小用byte ->
来表示 -> 建立或最近修改的时间 -> 名字
操作
输入 ls -al
7.2.3 cd 切换目录
cd全称Change Directory
语法
cd [参数]
参数说明
参数 | 功能 |
---|---|
cd 绝对路径 | 切换路径 |
cd 相对路径 | 切换路径 |
cd ~或者 cd | 回到自己的家目录 |
cd - | 回到上一次所在目录 |
cd .. | 回到当前目录的上一级目录 |
cd -P | 跳转到实际物理路径,而非快捷方式路径 |
7.2.4 mkdir 创建一个新的目录
mkdir 全称 Make directory 建立目录
语法
mkdir [选项] 要创建的目录
选项说明
-p 创建多层目录
操作
-
一次创建一个目录
输入
[root@hadoop101 ~]# mkdir xiyou
[root@hadoop101 ~]# mkdir xiyou/mingjie -
一次创建一个多级目录 -p
[root@hadoop101 ~]# mkdir -p xiyou/dssz/meihouwang
7.2.5 rmdir 删除一个空的目录
rmdir 全称 Remove directory 移除目录
语法
rmdir 要删除的空目录
操作
输入 redir d/e/f d/e/ d/
输入 redir -p g/h/i/
7.2.6 touch 创建空文件
语法
touch 文件名称
操作
输入 [root@hadoop101 ~]# touch xiyou/dssz/sunwukong.txt
7.2.7 cp 复制文件或目录
语法
cp [选项] source dest (功能描述:复制source文件到dest)
选项说明
-r 递归复制整个文件夹
参数说明
source 源文件
dest 目标文件
经验技巧
强制覆盖不提示的方法:\cp
操作
- 复制文件
[root@hadoop101 ~]# cp xiyou/dssz/suwukong.txt xiyou/mingjie/
如果cp前加个反斜杠,则不会询问是否覆盖,使用的是原生命令
[root@hadoop101 ~]# \cp xiyou/dssz/suwukong.txt xiyou/mingjie/
2. 递归复制整个文件夹
[root@hadoop101 ~]# cp -r xiyou/dssz/ ./
7.2.8 rm 删除文件或目录
语法
rm [选项] deleteFile (功能描述:递归删除目录中所有内容)
选项说明
-r 递归删除目录中所有内容
-f 强制执行删除操作,而不提示用于进行确认。
-v 显示指令的详细执行过程
操作
-
删除目录中的内容
[root@hadoop101 ~]# rm xiyou/mingjie/sunwukong.txt -
递归删除目录中所有内容
[root@hadoop101 ~]# rm -rf dssz/
7.2.9 mv 移动文件与目录或重命名
语法
(1)mv oldNameFile newNameFile (功能描述:重命名)
(2)mv /temp/movefile /targetFolder (功能描述:移动文件)
操作
(1)重命名
[root@hadoop101 ~]# mv xiyou/dssz/suwukong.txt xiyou/dssz/houge.txt
(2)移动文件
[root@hadoop101 ~]# mv xiyou/dssz/houge.txt ./
7.2.10 cat 查看文件内容
cat 全称 catch 捕捉当前文件名
语法
cat [选项] 要查看的文件
选项说明
-n 显示所有行的行号,包括空行。
操作
查看文件内容并显示行号
[atguigu@hadoop101 ~]$ cat -n houge.txt
7.2.11 more 文件内容分屏查看器
more 指令是一个基于 VI 编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。more 指令中内置了若干快捷键,详见操作说明。
语法
more 要查看的文件
怎么操作查看器
操作 | 功能说明 |
---|---|
空白键 (space) | 代表向下翻一页; |
Enter | 代表向下翻『一行』; |
q | 代表立刻离开 more ,不再显示该文件内容。Ctrl+F 向下滚动一屏 |
Ctrl+B | 返回上一屏 |
= | 输出当前行的行号 |
:f | 输出文件名和当前行的行号 |
操作
[root@hadoop101 ~]# more smartd.conf
7.2.12 less 分屏显示文件内容
less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比more 指令更加强大,支持各种显示终端。
less 指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,
对于显示大型文件具有较高的效率。
语法
less 要查看的文件
怎么操作查看器
操作 | 功能说明 |
---|---|
空白键 | 向下翻动一页; |
[pagedown] | 向下翻动一页 |
[pageup] | 向上翻动一页; |
/字串 | 向下搜寻『字串』的功能;n:向下查找;N:向上查找; |
?字串 | 向上搜寻『字串』的功能;n:向上查找;N:向下查找; |
q | 离开 less 这个程序; |
经验技巧
用SecureCRT时[pagedown]和[pageup]可能会出现无法识别的问题。
操作 查看less文件
[root@hadoop101 ~]# less smartd.conf
7.2.13 echo 输出内容到控制台
语法
echo [选项] [输出内容]
选项
-e: 支持反斜线控制的字符转换
控制字符 | 作用 |
---|---|
|输出\本身 | |
\n | 换行符 |
\t | 制表符,也就是 Tab 键 |
操作
输入 echo hello,world
输出 hello,world
输入 echo hello world
输出 hello world
输入 echo "hello world"
输出 hello world
输入 echo "hello\nworld"
输出 hello\nworld
输入 echo -e "hello\nworld"
输出
hello
world
7.2.14 head 显示文件头部内容
head 用于显示文件的开头部分内容,默认情况下 head 指令显示文件的前10 行内容
语法
head 文件 (功能描述:查看文件头10行内容)
head -n 5 文件 (功能描述:查看文件头5行内容,5可以是任意行数)
操作
-
显示十行
输入 head anaconda-ks.cfg -
显示5行
输入 head -n 5 anaconda-ks.cfg
7.2.15 tail 输出文件尾部内容
tail 用于输出文件中尾部的内容,默认情况下 tail 指令显示文件的后10 行内容。
语法
(1)tail 文件 (功能描述:查看文件尾部10行内容)
(2)tail -n 5 文件 (功能描述:查看文件尾部5行内容,5可以是任意行数)
(3)tail -f 文件
(-f 持续显示文件最新追加的内容,监视文件变化 切换另一个终端echo修改文件内容 会发生变化
ctrl+s(stop)暂停监视,ctrl+q(quit)继续监视,ctrl+(shift)+c退出)
-f
输入 ls -i info 查看文件索引
如果使用vim 修改文件会修改索引值,-f将无法监控,需要echo等重定向追加修改内容
7.2.16 > 输出重定向和 >> 追加
语法
(1)ls -l > 文件 (功能描述:列表的内容写入文件 a.txt 中(覆盖写))
(2)ls -al >> 文件 (功能描述:列表的内容追加到文件aa.txt 的末尾)
(3)cat 文件 1 > 文件 2 (功能描述:将文件 1 的内容覆盖到文件2)
(4)echo “内容” >> 文件 (终端写入内容追加到文件)
操作
(1)将 ls 查看信息写入到文件中 (ls -l 等于 ll)
-
输入 ll 查看列表内容
-
输入 ll > info 创建一个文件把ll列表内容放进去
-
输入 cat ll 查看文件内容
(2)采用 echo 将 hello 单词追加到文件中
-
输入 echo "hello,linux" >> info
-
输入 cat info
7.2.17 ln 软链接
ln 全称 link
软链接也称为符号链接,类似于 windows 里的快捷方式,有自己的数据块,主要存放了链接其他文件的路径。
语法
ln -s [原文件或目录] [软链接名或目录加软链接名] (功能描述:给原文件创建一个软链接)
注意
删除软链接: rm -rf 软链接名,而不是 rm -rf 软链接名/
如果使用 rm -rf 软链接名/ 删除,会把软链接对应的真实目录下内容删掉
查询:通过 ll 就可以查看,列表属性第 1 位是 l,尾部会有位置指向。
操作
-
文件软链接
去到要创建快捷键的目录
输入cd /home/mr155/
-
查看当前目录文件
输入ls
-
创建快捷键方式info在根目录
输入ln -s /root/info myInfo
-
查看快捷键文件
输入ls -l
-
目录软链接
创建目录/文件夹,创建文件
输入mkdir folder
输入touch folder/file
-
创建软链接
在mr155目录输入 ln -s /root/folder/ /home/mr155/myFolder
cd -P
软链接目录
进入软链接连接的目录
- 删除
rm -rf 文件名
7.2.18 history 查看已经执行过历史命令
语法
history
操作
输入 | 功能 |
---|---|
history | 查看已经执行过历史命令 |
history 10 | 查看已执行过的10条命令 |
!历史命令编号 | 显示当前编号的命令并执行 |
history -c | 删除历史命令记录 |
7.3 时间日期类
语法
date [OPTION] [+FORMAT]
OPTION选项说明
-d<时间字符串> 显示指定的“时间字符串”表示的时间,而非当前时间
-s<日期时间> 设置系统日期时间
FORMAT参数说明
<+日期时间格式> 指定显示时使用的日期时间格式
7.3.1 date 显示当前时间
语法
(1)date (功能描述:显示当前时间)
(2)date +%Y (功能描述:显示当前年份)
(3)date +%m (功能描述:显示当前月份)
(4)date +%d (功能描述:显示当前是哪一天)
(5)date "+%Y-%m-%d %H:%M:%S" (功能描述:显示年月日时分秒)
7.3.2 date 显示非当前时间
语法
(1)date -d '1 days ago' (功能描述:显示前一天时间)
(2)date -d '-1 days ago' (功能描述:显示明天时间)
7.3.3 date 设置系统时间
语法
date -s "2017-06-19 20:52:18" (字符串时间)
7.3.4 cal 查看日历
语法
cal [选项]
操作
输入 cal
显示当月日历
输入 cal -3
显示当月和前后两个月日历
输入 cal -m
显示以星期一开头的日历
输入 cal 2022
显示2022年的日历
输入 cal -y
显示当前年份的日历并高亮显示今天日期
7.3.5 恢复时间
先输入 yum install ntpdate
安装插件
再输入 ntpdate -u cn.pool.ntp.org
同步时间
7.4 用户管理命令
用户 如mr155
7.4.1 useradd 添加新用户
语法
useradd 用户名 (功能描述:添加新用户)
useradd -g 组名 用户名 (功能描述:添加新用户到某个组)
useradd -d 目录/名字 用户名
操作
输入 useradd tony
创建用户
在/home/目录查看用户
输入 useradd -d /home/dave david
创建用户名的文件夹为dave,用户名为david
7.4.2 passwd 设置用户密码
语法
passwd 用户名
然后输入密码
操作
输入 passwd tony
xshell新建连接
exit 退出
7.4.3 id 查看用户是否存在
语法
id 用户名
操作
7.4.4 cat /etc/passwd 查看创建了哪些用户
操作
输入 cat /etc/passwd
滑到最后
7.4.5 su 切换用户 swith user
语法
su 用户名称 (功能描述:切换用户,只能获得用户的执行权限,不能获得环境变量)
su - 用户名称 (功能描述:切换到用户并获得该用户的环境变量及执行权限)
exit 退回上一个用户
操作
7.4.6 userdel 删除用户
语法
(1)userdel 用户名 (功能描述:删除用户但保存用户主目录)
(2)userdel -r 用户名 (功能描述:用户和用户主目录,都删除)
-r 删除用户的同时,删除与用户相关的所有文件。
操作
(1)删除用户但保存用户主目录
输入 userdel tony
, home目录的tony文件还在,id tony
和cat /etc/passwd
的tony不在了
可以再次删除tony目录文件全部删除
输入 rm -rf tony/
(2)删除用户和用户主目录,都删除
输入 userdel -r david
7.4.7 who 查看登录用户信息
语法
(1)whoami (功能描述:显示自身用户名称)
(2)who am i (功能描述:显示登录用户的用户名以及登陆时间)
操作
7.4.8 sudo 设置普通用户具有 root 权限
-
在root用户下进行
-
输入
vim /etc/sudoers
修改文件 ctrl+f 下一页 ctrl+b 上一页 在第一百页yy复制 p粘贴
-
输入
su tony
切换用户,直接输入ls
查看内容会没有权限,输入sudo ls
即可查看
7.4.9 usermod 修改用户
语法
usermod -g 用户组 用户名
(-g 修改用户的初始登录组,给定的组必须存在。默认组id 是1。)
操作
usermod -g meifa tony
7.5 用户组管理命令
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,
如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
7.5.1 groupadd 新增组
语法
groupadd 组名
操作
(1)添加一个meifa组
输入 groupadd meifa
输入 cat /etc/group
查看
7.5.2 groupdel 删除组
语法
groupdel 组名
操作
(1)删除tony和david组
输入 groupdel tony
和groupdel david
输入 cat /etc/group
查看
7.5.3 groupmod 修改组 和 usermod 修改用户
语法
groupmod -n 新组名 老组名
(-n<新组名> 指定工作组的新组名)
usermod -g 新组名 老组名
(usermod -g meifa tony
修改tony成meifa这组
-g 修改用户的初始登录组,给定的组必须存在。默认组id 是1。)
操作
(1)修改tony和david为meifa这组
输入 usermod -g meifa tony
输入 usermod -g meifa david
输入查看 id tony
id david
(2)修改meifa组名称为haircut
输入 groupmod -n haircut meifa
输入 cat /etc/group
查看
7.5.4 cat /etc/group 查看创建了哪些组
操作
输入 cat /etc/group
7.6 文件权限类
7.6.1 文件属性
Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。在Linux中我们可以使用ll或者ls -l命令来显示一个文件的属性以及文件所属的用户和组。
- 示范rwx
如:
从左到右的 10 个字符表示,减号为没有权限
(1)0 首位表示类型
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等
- 代表文件
d 代表目录
l 链接文档(link file);
(2)第1-3位确定属主(该文件的所有者)拥有该文件的权限。---User
(3)第4-6位确定属组(所有者的同组用户)拥有该文件的权限,---Group
(4)第7-9位确定其他用户拥有该文件的权限 ---Other
-
rwx 作用文件和目录的不同解释
(1)作用到文件:
[ r ]代表可读(read): 可以读取,查看
[ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件.
[ x ]代表可执行(execute):可以被系统执行
(2)作用到目录:
[ r ]代表可读(read): 可以读取,ls查看目录内容
[ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
[ x ]代表可执行(execute):可以进入该目录 -
文件其他属性介绍
(1)如果查看到是文件:链接数指的是硬链接个数。
(2)如果查看的是文件夹:链接数指的是子文件夹个数。
7.6.2 chmod 改变权限
语法
u=user g=group o=other a=all
第一种方式变更权限
chmod [{ugoa}{+-=}{rwx}]
文件或目录
=号是直接替换,+号是增加,-号是去掉
第二种方式变更权限
chmod [mode=421]
[文件或目录]
第二种方式的技巧
u:所有者 g:所有组 o:其他人 a:所有人(u、g、o 的总和)
r=4 w=2 x=1 rwx=4+2+1=7
操作
(1)修改文件使其所属主用户具有执行权限
[root@hadoop101 ~]# cp xiyou/dssz/houge.txt ./
[root@hadoop101 ~]# chmod u+x houge.txt
(2)修改文件使其所属组用户具有执行权限
[root@hadoop101 ~]# chmod g+x houge.txt
(3)修改文件所属主用户执行权限,并使其他用户具有执行权限
[root@hadoop101 ~]# chmod u-x,o+x houge.txt
(4)采用数字的方式,设置文件所有者、所属组、其他用户都具有可读可写可执行权限。
[root@hadoop101 ~]# chmod 777 houge.txt
(5)修改整个文件夹里面的所有文件的所有者、所属组、其他用户都具有可读可写可执行权限。
[root@hadoop101 ~]# chmod -R 777 xiyou/
7.6.3 chown 改变所有者change own
语法
chown [选项] [最终用户] [文件或目录]
(功能描述:改变文件或者目录的所有者)
选项的 -R 递归操作
操作
(1)修改文件所有者user
[root@hadoop101 ~]# chown atguigu houge.txt
[root@hadoop101 ~]# ls -al
-rwxrwxrwx. 1 atguigu root 551 5 月 23 13:02 houge.txt
(2)递归改变文件所有者user和所有组group
[root@hadoop101 xiyou]# ll
drwxrwxrwx. 2 root root 4096 9 月 3 21:20 xiyou
[root@hadoop101 xiyou]# chown -R atguigu:atguigu xiyou/
[root@hadoop101 xiyou]# ll
drwxrwxrwx. 2 atguigu atguigu 4096 9 月 3 21:20 xiyou
7.6.4 chgrp 改变所属组change group
语法
chgrp [最终用户组] [文件或目录]
(功能描述:改变文件或者目录的所属组)
操作
(1)修改文件的所属组
[root@hadoop101 ~]# chgrp root houge.txt
[root@hadoop101 ~]# ls -al
-rwxrwxrwx. 1 atguigu root 551 5 月 23 13:02 houge.txt
7.7 搜索查找类
7.7.1 find 查找文件或者目录
find 指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端。
语法
find [搜索范围] [选项]
选项说明
选项 | 功能 |
---|---|
-name<查询方式> | 按照指定的文件名查找模式查找文件 |
-user<用户名> | 查找属于指定用户名所有文件 |
-size<文件大小> | 按照指定的文件大小查找文件,单位为: b —— 块(512 字节) c —— 字节 w —— 字(2 字节) k —— 千字节 M —— 兆字节 G —— 吉字节 |
操作
(1)按文件名:根据名称查找/目录下的info文件。
输入 find -name info
输入 find /root -name "*.cfg"
后缀查找
(2)按拥有者:查找/home目录下,用户名称为tony的文件
输入 find /home -user tony
(3)按文件大小:在/home目录下查找大于200m的文件(+n 大于-n小于n等于)
输入 ls -lh 可查看文件mk大小
输入 find /root -size +1k
或
[root@hadoop101 ~]find /home -size +204800
7.7.2 locate 快速定位文件路径
locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给定的文件。
Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate 时刻。
语法
locate 搜索文件
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用updatedb 指令创建 locate 数据库。
操作
(1)查询文件夹
[root@hadoop101 ~]# updatedb
[root@hadoop101 ~]#locate tmp
(2)which 命令
查询命令的位置
7.7.3 grep 过滤查找及“|”管道符
管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
语法
grep 选项 查找内容 源文件
(选项 -n 显示匹配行及行号。)
wc
(work count 查询单词数量 空格为间隔)
操作
(1)查询initial-setup-ks.cfg文件里的关键字boot 显示行号和高亮关键字
输入 grep -n boot initial-setup-ks.cfg
(2)查询ls里是.cdg后缀的文件
输入 ls | grep .cfg
(3)wc查询单词统计
输入 wc info
(4) 查询(1)结果里的单词统计
输入 grep -n boot initial-setup-ks.cfg | wc
7.8 压缩和解压类
7.8.1 gzip/gunzip 压缩 文件 (不常用)
语法
gzip 文件
(功能描述:压缩文件,只能将文件压缩为*.gz 文件)
gunzip 文件.gz
(功能描述:解压缩文件命令)
注意
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件
(3)同时多个文件会产生多个压缩包
zip/unzip 压缩 文件和目录
语法
zip [选项] XXX.zip 将要压缩的内容
(功能描述:压缩文件和目录的命令)
选项 -r 压缩目录
unzip [选项] XXX.zip
(功能描述:解压缩文件)
选项 -d<目录> 指定解压后文件的存放目录
注意
zip 压缩命令在windows/linux都通用,可以压缩目录且保留源文件。
操作
(1)压缩根目录(/root) (myroot.zip是压缩后别名) (-r是压缩目录时加上的)
输入 zip -r myroot.zip /root
再输入 ls -lh
查询
(2)解压文件到指定目录
输入 unzip -d /tmp myroot.zip
进入tmp查看
(3)压缩两个文件info和info1
输入 zip infoall.zip info info1
7.8.3 tar 打包 一般用原大小打包再压缩
语法
tar [选项] XXX.tar.gz 将要打包进去的内容
(功能描述:打包目录,压缩后的文件格式.tar.gz)
选项说明 可多选 压缩-zcvf 解压-zxvf(不加-z也行,系统自动识别)
选项 | 功能 |
---|---|
-c | 产生.tar 打包文件 |
-v | 显示详细信息 |
-f | 指定压缩后的文件名 |
-z | 打包同时压缩 |
-x | 解包.tar 文件 |
-C | 解压到指定目录 |
操作
(1)压缩多个文件initial-setup-ks.cfg info info1 公共/
输入 tar -zcvf temp.tar.gz initial-setup-ks.cfg info info1 公共/
(2)解压文件解压-zxvf temp.tar.gz 到(-C) /tmp目录
输入 tar -zxvf temp.tar.gz -C /tmp
7.9 磁盘查看和分区类
安装tree插件
输入 yum install tree
使用 输入 tree ./
查询根目录情况
7.9.1 du 查看文件和目录占用的磁盘空间
du 全称 disk usage 磁盘占用情况
语法
du [目录/文件]
(功能描述:显示目录下每个子目录的磁盘使用情况,一般目录用,文件就ll)
选项说明
选项 | 功能 |
---|---|
-h | 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示; |
-a | 不仅查看子目录大小,还要包括文件 |
-c | 显示所有的文件和子目录大小后,显示总和(不常用) |
-s | 只显示总和 |
--max-depth=n | 指定统计子目录的深度为第 n 层 |
操作
(1)查看当前用户主目录占用的磁盘空间大小
输入 du -sh
(2)查询所有子目录
输入 du
显示所有子目录
输入 du -h
大小换GBytes, MBytes, KBytes显示
输入 du -ah
显示目录还有文件大小
(3)按子目录层级显示目录和文件
输入 du --max-depth=1 -ah
7.9.2 df 查看磁盘空间使用情况
df 全称 disk free 空余磁盘
语法
df 选项
(功能描述:列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占用情况)
选项 -h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
操作
输入 df -h
输入 free -h
交换分区swap
7.9.4 lsblk 查看设备挂载情况
语法
lsblk [选项]
(功能描述:查看设备挂载情况)
选项 -f 查看详细的设备挂载情况,显示文件系统信息
操作
7.9.5 mount/umount 挂载/卸载
对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根目录、一个独立且唯一的文件结构。
Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。
挂载前准备(必须要有光盘或者已经连接镜像文件)
语法
mount [-t vfstype] [-o options] device dir
(功能描述:挂载设备)
umount 设备文件名或挂载点
(功能描述:卸载设备)
参数说明
参数 | 功能 |
---|---|
-t vfstype | 指定文件系统的类型,通常不必指定。mount 会自动选择正确的类型。常用类型有: 光盘或光盘镜像:iso9660(默认) DOS fat16 文件系统:msdos Windows 9x fat32 文件系统:vfat Windows NT ntfs 文件系统:ntfs Mount Windows 文件网络共享:smbfs UNIX(LINUX) 文件网络共享:nfs |
-o options | 主要用来描述设备或档案的挂接方式。常用的参数有: loop:用来把一个文件当成硬盘分区挂接上系统 ro:采用只读方式挂接设备 rw:采用读写方式挂接设备 iocharset:指定访问文件系统所用字符集 |
device | 要挂接(mount)的设备 |
dir | 设备在系统上的挂接点(mount point) |
操作
-
弹出桌面光盘
-
输入lsblk 查询
-
开始手动挂载 测试
先输入mkdir /mnt/cdrom
创建新的挂载点目录 -
退出linux图形化界面 右上角关机键进行注销root
-
虚拟机设置改成已连接
-
输入
mount /dev/cdrom /mnt/cdrom/
挂载
但是 mount: /dev/sr0 写保护,将以只读方式挂载
现在/dev/cdrom和/mnt/cdrom/是映射关系
-
卸载设备
输入umount /dev/cdrom
其他
设置开机自动挂载
-
输入
vim /etc/fstab
-
修改 加入
/dev/cdrom /mnt/cdrom iso9960 defaults 0 0
7.9.5 fdisk 分区
语法
fdisk -l
(功能描述:查看磁盘分区详情 -l 显示所有硬盘的分区列表)
fdisk 硬盘设备名
(功能描述:对新增硬盘进行分区操作)
该命令必须在 root 用户下才能使用
mkfs(英文全拼:make file system)命令用于在特定的分区上建立 linux 文件系统。
mkfs [-V] [-t fstype] [fs-options] filesys [blocks]
如:mkfs -t xfs /dev/sdb1
参数
- device : 预备检查的硬盘分区,例如:/dev/sda1
- -V : 详细显示模式
- -t : 给定档案系统的型式,Linux 的预设值为 ext2
- -c : 在制做档案系统前,检查该partition 是否有坏轨
- -l bad_blocks_file : 将有坏轨的block资料加到 bad_blocks_file 里面
- block : 给定 block 的大小
功能说明
(1)Linux 分区
Device:分区序列
Boot:引导
Start:从X磁柱开始
End:到Y磁柱结束
Blocks:容量
Id:分区类型ID
System:分区类型
(2)分区操作按键说明
m:显示命令列表
p:显示当前磁盘分区
n:新增分区
w:写入分区信息并退出
q:不保存分区信息直接退出
操作
(1) 输入 fdisk -l
查看磁盘分区详情
(2) 添加硬盘
-
设置
-
reboot重启
-
输入
lsblk
fdisk -l
查看磁盘分区
-
输入
fdisk /dev/sdb
对新增硬盘进行分区操作
-
输入
m
查看帮助
-
输入
n
添加新分区 一直回车确定既是默认值
-
输入
w
将表写入磁盘并退出
-
此时
fdisk -l
-
输入
mkfs -t xfs /dev/sdb1
格式化
-
输入
lsblk -f
查看 发现多了一段
-
输入
mount /dev/sdb1 /home/mr155/
添加挂载点 输入lsblk -f
查看
-
输入
df -h
查看新磁盘占用空间
-
卸载挂载点 输入
umount /home/mr155
或umount /dev/sdb1
输入df -h
查看
7.10 进程管理类
进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。
7.10.1 ps 查看当前系统进程状态 ps:process status 进程状态
语法
ps aux | grep xxx (功能描述:查看系统中所有进程)
ps -ef | grep xxx (功能描述:可以查看子父进程之间的关系)
如果想查看进程的 CPU 占用率和内存占用率,可以使用 aux;
如果想查看进程的父进程 ID 可以使用 ef;
选项说明
选项 | 功能 |
---|---|
a | 列出带有终端的所有用户的进程 |
x | 列出当前用户的所有进程,包括没有终端的进程u 面向用户友好的显示风格 |
-e | 列出所有进程 |
-u | 列出某个用户关联的所有进程 |
-f | 显示完整格式的进程列表 |
功能说明
(1)ps aux 显示信息说明
- USER:该进程是由哪个用户产生的
- ==PID:进程的 ID 号
- %CPU:该进程占用 CPU 资源的百分比,占用越高,进程越耗费资源;
- %MEM:该进程占用物理内存的百分比,占用越高,进程越耗费资源;==
- VSZ:该进程占用虚拟内存的大小,单位 KB;
- RSS:该进程占用实际物理内存的大小,单位 KB;
- TTY:该进程是在哪个终端中运行的。对于 CentOS 来说,tty1 是图形化终端,tty2-tty6 是本地的字符界面终端。pts/0-255 代表虚拟终端。
- STAT:进程状态。常见的状态有:R:运行状态、S:睡眠状态、T:暂停状态、
Z:僵尸状态、s:包含子进程、l:多线程、+:前台显示、<:运行优先级最高、 N、运行优先级最低 - START:该进程的启动时间
- TIME:该进程占用 CPU 的运算时间,注意不是系统时间
- COMMAND:产生此进程的命令名
(2)ps -ef 显示信息说明
- UID:用户 ID
- PID:进程 ID
- PPID:父进程 ID
- C:CPU 用于计算执行优先级的因子。数值越大,表明进程是CPU 密集型运算,执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高STIME:进程启动的时间
- TTY:完整的终端名称
- TIME:CPU 时间
- CMD:启动进程所用的命令和参数
操作
-
输入
ls /usr/lib/systemd/system | grep d.service
查看守护进程
-
输入
ps -ef | grep sshd
查看远程登录进程
7.10.2 kill 终止进程
语法
kill [选项] 进程号
(功能描述:通过进程号杀死进程 选项 -9 表示强迫进程立即停止)
killall 进程名称
(功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)
操作
-
打开多几个终端 输入
ps -ef | grep sshd
-
输入
kill 5362
杀死这个终端
-
如果输入
killall sshd
会杀死全部远程连接进程(包括守护进程)
需要进入linux终端输入systemctl strat sshd
启动远程连接进程
7.10.3 pstree 查看进程树
语法
pstree [选项] (选项 -p 显示进程的PID -u 显示进程的所属用户)
操作
-
pstree是插件,需要提前按装 输入
yum install pstree
-
输入
pstree
查看进程pstree | less
分页查看
-
输入
pstree -p | less
显示进程的PID
-
输入
pstree -u | less
显示进程的所属用户
7.10.4 top 实时监控系统进程状态
语法
top [选项]
选项说明
选项 | 功能 |
---|---|
-d 秒数 | 指定 top 命令每隔几秒更新。默认是 3 秒在 top 命令的交互模式当中可以执行的命令: |
-i | 使 top 不显示任何闲置或者僵死进程。 |
-p | 通过指定监控进程 ID 来仅仅监控某个进程的状态。 |
操作说明
操作 | 功能 |
---|---|
P | 以 CPU 使用率排序,默认就是此项 |
M | 以内存的使用率排序 |
N | 以 PID 排序 |
q | 退出 top |
查询结果字段解释
第一行信息为任务队列信息
内容 | 说明 |
---|---|
12:26:46 | 系统当前时间 |
up 4:40, | 系统的运行时间 |
3 users, | 当前登录了三个用户 |
load average: 0.00, 0.01, 0.05 | 系统在之前 1 分钟,5 分钟,15 分钟的平均负载。一般认为小于 1 时,负载较小。如果大于1,系统已经超出负荷。 |
第二行为进程信息
内容 | 说明 |
---|---|
Tasks: 234 total, | 系统中的进程总数 |
1 running, | 正在运行的进程数 |
233 sleeping, | 睡眠的进程 |
0 stopped, | 正在停止的进程 |
0 zombie | 僵尸进程。如果不是 0,需要手工检查僵尸进程 |
第三行为 CPU 信息
内容 | 说明 |
---|---|
%Cpu(s): 0.0 us, | 用户模式占用的 CPU 百分比 |
0.3 sy, | 系统模式占用的 CPU 百分比 |
0.0 ni, | 改变过优先级的用户进程占用的CPU 百分比 |
100.0 id, | 空闲 CPU 的 CPU 百分比 |
0.0 wa, | 等待输入/输出的进程的占用CPU 百分比 |
0.0 hi, | 硬中断请求服务占用的 CPU 百分比 |
0.0 si, | 软中断请求服务占用的 CPU 百分比 |
0.0 st | st(Steal time)虚拟时间百分比。就是当有虚拟机时,虚拟 CPU 等待实际 CPU 的时间百分比。 |
第四行为物理内存信息
内容 | 说明 |
---|---|
KiB Mem : 4025948 total, | 物理内存的总量,单位 KB |
2372108 free, | 空闲的物理内存数量,我们使用的是虚拟机,总共只分配了 628MB 内存,所以只有53MB的空闲内存了 |
856384 used, | 已经使用的物理内存数量 |
797456 buff/cache | 作为缓冲的内存数量 |
第五行为交换分区(swap)信息
内容 | 说明 |
---|---|
KiB Swap: 4194300 total, | 交换分区(虚拟内存)的总大小 |
4194300 free, | 空闲交换分区的大小 |
0 used. | 已经使用的交互分区的大小 |
2887920 avail Mem | 作为缓存的交互分区的大小 |
操作
-
一秒刷新一次
[root@hadoop101 atguigu]# top -d 1 -
使 top 不显示任何闲置或者僵死进程。
[root@hadoop101 atguigu]# top -i -
通过指定监控进程 ID 来仅仅监控某个进程的状态。
[root@hadoop101 atguigu]# top -p 2575
7.10.5 netstat 显示网络状态和端口占用信息
语法
netstat -anp | grep 进程号 (功能描述:查看该进程网络信息)
netstat –nlp | grep 端口号 (功能描述:查看网络端口号占用情况)
选项说明
选项 | 功能 |
---|---|
-a | 显示所有正在监听(listen)和未监听的套接字(socket) |
-n | 拒绝显示别名,能显示数字的全部转化成数字 |
-l | 仅列出在监听的服务状态 |
-p | 表示显示哪个进程在调用 |
操作
输入 netstat -anp | less
输入 netstat -nlp | less
7.11 crontab 系统定时任务
7.11.1 crontab 服务管理
重新启动 crond 服务
[root@hadoop101 ~]# systemctl restart crond
7.11.2 crontab 定时任务设置
语法
crontab [选项]
选项说明
选项 | 功能 |
---|---|
-e | 编辑 crontab 定时任务 |
-l | 查询 crontab 任务 |
-r | 删除当前用户所有的 crontab 任务 |
参数说明
输入 crontab -e
(1)进入 crontab 编辑界面。会打开 vim 编辑你的工作。
语法: * * * * * 执行的任务
项目 | 含义 | 范围 |
---|---|---|
第一个“*” | 一小时当中的第几分钟 | 0-59 |
第二个“*” | 一天当中的第几小时 | 0-23 |
第三个“*” | 一个月当中的第几天 | 1-31 |
第四个“*” | 一年当中的第几月 | 1-12 |
第五个“*” | 一周当中的星期几 | 0-7 (0 和7 都代表星期日) |
(2)特殊符号
特殊符号 | 含义 |
---|---|
* | 代表任何时间。比如第一个“*”就代表一小时中每分钟都执行一次的意思。 |
, | 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表在每天的 8 点 0 分,12 点 0 分,16 点0 分都执行一次命令 |
- | 代表连续的时间范围。比如“0 5 * * 1-6 命令”,代表在周一到周六的凌晨 5 点 0 分执行命令 |
*/n | 代表每隔多久执行一次。比如“*/10 * * * * 命令”,代表每隔 10 分钟就执行一遍命令 |
(3)特定时间执行命令
时间 | 含义 |
---|---|
45 22 * * * 命令 | 每天 22 点 45 分执行命令 |
0 17 * * 1 命令 | 每周 1 的 17 点 0 分执行命令 |
0 5 1,15 * * 命令 | 每月 1 号和 15 号的凌晨 5 点 0 分执行命令 |
40 4 * * 1-5 命令 | 每周一到周五的凌晨 4 点 40 分执行命令 |
*/10 4 * * * 命令 | 每天的凌晨 4 点,每隔 10 分钟执行一次命令 |
0 0 1,15 * 1 命令 | 每月 1 号和 15 号,每周 1 的 0 点 0 分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。 |
操作
-
输入
crontab -e
打开编辑定时任务界面
填入*/1 * * * * echo "hello,world" >> /root/hello
每隔 1 分钟,向/root/hello 文件中添加一个 hello,world 的数字
-
输入
ls
查看,没有hello文件会自动创建一个
-
输入
tail -f hello
实时查看变化
-
输入
crontab -l
查询 crontab 任务
-
输入
crontab -r
删除当前用户所有的 crontab 任务