首页 > 其他分享 >第七章 常用基本命令(重要)

第七章 常用基本命令(重要)

时间:2022-12-21 20:55:06浏览次数:40  
标签:文件 常用 查看 命令 第七章 进程 root 目录 输入

第 7 章 常用基本命令(重要)Shell命令

Shell 可以看作是一个命令解释器,为我们提供了交互式的文本控制台界面。我们可以通过终端控制台来输入命令,由 shell 进行解释并最终交给内核执行。本章就将分类介绍常用的基本 shell 命令。

7.1 帮助命令

7.1.1 man 获得帮助信息 (manual 手册,说明书)

语法

man [命令或配置文件]

操作后显示说明

信息 功能
NAME 命令的名称和单行描述
SYNOPSIS 怎样使用命令
DESCRIPTION 命令功能的深入讨论
EXAMPLES 怎样使用命令的例子
SEE ALSO 相关主题(通常是手册页)

操作方法

输入 man ls 查看 ls 命令的帮助信息
image

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
image

7.2.2 ls 列出目录的内容

ls全称list

语法

ls [选项] [目录或是文件]

选项说明

-a 全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
-l 长数据串列出,包含文件的属性与权限等等数据;(常用)等价于“ll”

显示说明

每行列出的信息依次是:
文件类型与权限 -> 链接数 -> 文件属主 -> 文件属组文件大小用byte ->
来表示 -> 建立或最近修改的时间 -> 名字

操作

输入 ls -al
image

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 创建多层目录

操作

  1. 一次创建一个目录
    输入
    [root@hadoop101 ~]# mkdir xiyou
    [root@hadoop101 ~]# mkdir xiyou/mingjie

  2. 一次创建一个多级目录 -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

操作

  1. 复制文件
    [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 显示指令的详细执行过程

操作

  1. 删除目录中的内容
    [root@hadoop101 ~]# rm xiyou/mingjie/sunwukong.txt

  2. 递归删除目录中所有内容
    [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可以是任意行数)

操作

  1. 显示十行
    输入 head anaconda-ks.cfg

  2. 显示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 查看文件索引
image

如果使用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)

  1. 输入 ll 查看列表内容
    image

  2. 输入 ll > info 创建一个文件把ll列表内容放进去

  3. 输入 cat ll 查看文件内容
    image

(2)采用 echo 将 hello 单词追加到文件中

  1. 输入 echo "hello,linux" >> info

  2. 输入 cat info
    image

7.2.17 ln 软链接

ln 全称 link
软链接也称为符号链接,类似于 windows 里的快捷方式,有自己的数据块,主要存放了链接其他文件的路径。

语法

ln -s [原文件或目录] [软链接名或目录加软链接名] (功能描述:给原文件创建一个软链接)

注意

删除软链接: rm -rf 软链接名,而不是 rm -rf 软链接名/
如果使用 rm -rf 软链接名/ 删除,会把软链接对应的真实目录下内容删掉
查询:通过 ll 就可以查看,列表属性第 1 位是 l,尾部会有位置指向。

操作

  1. 文件软链接
    去到要创建快捷键的目录
    输入 cd /home/mr155/

  2. 查看当前目录文件
    输入 ls
    image

  3. 创建快捷键方式info在根目录
    输入 ln -s /root/info myInfo

  4. 查看快捷键文件
    输入 ls -l
    image


  1. 目录软链接
    创建目录/文件夹,创建文件
    输入 mkdir folder
    输入 touch folder/file
    image

  2. 创建软链接
    在mr155目录输入 ln -s /root/folder/ /home/mr155/myFolder
    image

image


  1. cd -P 软链接目录
    进入软链接连接的目录
    image

  1. 删除 rm -rf 文件名
    image

7.2.18 history 查看已经执行过历史命令

语法

history

操作

输入 功能
history 查看已经执行过历史命令
history 10 查看已执行过的10条命令
!历史命令编号 显示当前编号的命令并执行
history -c 删除历史命令记录

image

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 显示当月日历
image

输入 cal -3 显示当月和前后两个月日历
image

输入 cal -m 显示以星期一开头的日历
image

输入 cal 2022 显示2022年的日历
image

输入 cal -y 显示当前年份的日历并高亮显示今天日期
image

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 创建用户
image

在/home/目录查看用户
image

输入 useradd -d /home/dave david 创建用户名的文件夹为dave,用户名为david
image

7.4.2 passwd 设置用户密码

语法

passwd 用户名
然后输入密码

操作

输入 passwd tony
image

xshell新建连接
image

image

image

exit 退出

7.4.3 id 查看用户是否存在

语法

id 用户名

操作

image

7.4.4 cat /etc/passwd 查看创建了哪些用户

操作

输入 cat /etc/passwd
image

滑到最后
image

7.4.5 su 切换用户 swith user

语法

su 用户名称 (功能描述:切换用户,只能获得用户的执行权限,不能获得环境变量)
su - 用户名称 (功能描述:切换到用户并获得该用户的环境变量及执行权限)
exit 退回上一个用户

操作

image

7.4.6 userdel 删除用户

语法

(1)userdel 用户名 (功能描述:删除用户但保存用户主目录)
(2)userdel -r 用户名 (功能描述:用户和用户主目录,都删除)
-r 删除用户的同时,删除与用户相关的所有文件。

操作

(1)删除用户但保存用户主目录
输入 userdel tony, home目录的tony文件还在,id tonycat /etc/passwd的tony不在了
image

可以再次删除tony目录文件全部删除
输入 rm -rf tony/
image

(2)删除用户和用户主目录,都删除
输入 userdel -r david
image

7.4.7 who 查看登录用户信息

语法

(1)whoami (功能描述:显示自身用户名称)
(2)who am i (功能描述:显示登录用户的用户名以及登陆时间)

操作

image

7.4.8 sudo 设置普通用户具有 root 权限

  1. 在root用户下进行

  2. 输入 vim /etc/sudoers 修改文件 ctrl+f 下一页 ctrl+b 上一页 在第一百页yy复制 p粘贴
    image

  3. 输入 su tony 切换用户,直接输入ls查看内容会没有权限,输入sudo ls即可查看
    image

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 查看
image

7.5.2 groupdel 删除组

语法

groupdel 组名

操作

(1)删除tony和david组
输入 groupdel tonygroupdel david
image

输入 cat /etc/group 查看
image

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
image

(2)修改meifa组名称为haircut
输入 groupmod -n haircut meifa
image

输入 cat /etc/group 查看
image

7.5.4 cat /etc/group 查看创建了哪些组

操作

输入 cat /etc/group

7.6 文件权限类

7.6.1 文件属性

Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。在Linux中我们可以使用ll或者ls -l命令来显示一个文件的属性以及文件所属的用户和组。

  1. 示范rwx
    如:
    image

从左到右的 10 个字符表示,减号为没有权限
image
(1)0 首位表示类型
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等
- 代表文件
d 代表目录
l 链接文档(link file)
(2)第1-3位确定属主(该文件的所有者)拥有该文件的权限。---User
(3)第4-6位确定属组(所有者的同组用户)拥有该文件的权限,---Group
(4)第7-9位确定其他用户拥有该文件的权限 ---Other


  1. rwx 作用文件和目录的不同解释
    (1)作用到文件:
    [ r ]代表可读(read): 可以读取,查看
    [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件.
    [ x ]代表可执行(execute):可以被系统执行
    (2)作用到目录:
    [ r ]代表可读(read): 可以读取,ls查看目录内容
    [ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
    [ x ]代表可执行(execute):可以进入该目录

  2. 文件其他属性介绍
    image
    (1)如果查看到是文件:链接数指的是硬链接个数。
    (2)如果查看的是文件夹:链接数指的是子文件夹个数。

7.6.2 chmod 改变权限

语法

image

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" 后缀查找
image

(2)按拥有者:查找/home目录下,用户名称为tony的文件
输入 find /home -user tony
image

(3)按文件大小:在/home目录下查找大于200m的文件(+n 大于-n小于n等于)
输入 ls -lh 可查看文件mk大小
image

输入 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 命令 查询命令的位置
image

7.7.3 grep 过滤查找及“|”管道符

管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理

语法

grep 选项 查找内容 源文件
(选项 -n 显示匹配行及行号。)

wc(work count 查询单词数量 空格为间隔)

操作

(1)查询initial-setup-ks.cfg文件里的关键字boot 显示行号和高亮关键字
输入 grep -n boot initial-setup-ks.cfg
image

(2)查询ls里是.cdg后缀的文件
输入 ls | grep .cfg
image

(3)wc查询单词统计
输入 wc info
image

(4) 查询(1)结果里的单词统计
输入 grep -n boot initial-setup-ks.cfg | wc
image

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 查询
image

(2)解压文件到指定目录
输入 unzip -d /tmp myroot.zip
进入tmp查看
image

(3)压缩两个文件info和info1
输入 zip infoall.zip info info1
image

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 公共/
image

(2)解压文件解压-zxvf temp.tar.gz 到(-C) /tmp目录
输入 tar -zxvf temp.tar.gz -C /tmp
image

7.9 磁盘查看和分区类

安装tree插件
输入 yum install tree
使用 输入 tree ./ 查询根目录情况
image

7.9.1 du 查看文件和目录占用的磁盘空间

du 全称 disk usage 磁盘占用情况

语法

du [目录/文件] (功能描述:显示目录下每个子目录的磁盘使用情况,一般目录用,文件就ll)

选项说明

选项 功能
-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
-a 不仅查看子目录大小,还要包括文件
-c 显示所有的文件和子目录大小后,显示总和(不常用)
-s 只显示总和
--max-depth=n 指定统计子目录的深度为第 n 层

操作

(1)查看当前用户主目录占用的磁盘空间大小
输入 du -sh
image

(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
image

输入 free -h 交换分区swap
image

7.9.4 lsblk 查看设备挂载情况

语法

lsblk [选项] (功能描述:查看设备挂载情况)
选项 -f 查看详细的设备挂载情况,显示文件系统信息

操作

image

7.9.5 mount/umount 挂载/卸载

对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根目录、一个独立且唯一的文件结构。
Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。

挂载前准备(必须要有光盘或者已经连接镜像文件)

image

image

语法

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)

操作

  1. 弹出桌面光盘
    image

  2. 输入lsblk 查询
    image

  3. 开始手动挂载 测试
    先输入 mkdir /mnt/cdrom 创建新的挂载点目录

  4. 退出linux图形化界面 右上角关机键进行注销root

  5. 虚拟机设置改成已连接
    image

  6. 输入 mount /dev/cdrom /mnt/cdrom/ 挂载
    但是 mount: /dev/sr0 写保护,将以只读方式挂载
    现在/dev/cdrom和/mnt/cdrom/是映射关系
    image

  7. 卸载设备
    输入 umount /dev/cdrom
    image
    其他
    image

设置开机自动挂载

  1. 输入vim /etc/fstab
    image

  2. 修改 加入

/dev/cdrom                                /mnt/cdrom              iso9960 defaults        0 0

image

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 查看磁盘分区详情
image

(2) 添加硬盘

  1. 设置
    image

  2. reboot重启

  3. 输入 lsblk fdisk -l 查看磁盘分区
    image

image

  1. 输入 fdisk /dev/sdb 对新增硬盘进行分区操作
    image

  2. 输入 m 查看帮助
    image

  3. 输入 n 添加新分区 一直回车确定既是默认值
    image

  4. 输入 w 将表写入磁盘并退出
    image

  5. 此时 fdisk -l
    image

  6. 输入 mkfs -t xfs /dev/sdb1 格式化
    image

  7. 输入 lsblk -f查看 发现多了一段
    image

  8. 输入 mount /dev/sdb1 /home/mr155/ 添加挂载点 输入 lsblk -f 查看
    image

  9. 输入df -h查看新磁盘占用空间
    image

  10. 卸载挂载点 输入 umount /home/mr155umount /dev/sdb1
    输入 df -h 查看
    image

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:产生此进程的命令名

image

(2)ps -ef 显示信息说明

  • UID:用户 ID
  • PID:进程 ID
  • PPID:父进程 ID
  • C:CPU 用于计算执行优先级的因子。数值越大,表明进程是CPU 密集型运算,执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高STIME:进程启动的时间
  • TTY:完整的终端名称
  • TIME:CPU 时间
  • CMD:启动进程所用的命令和参数

image

操作

  1. 输入 ls /usr/lib/systemd/system | grep d.service 查看守护进程
    image

  2. 输入 ps -ef | grep sshd 查看远程登录进程
    image

7.10.2 kill 终止进程

语法

kill [选项] 进程号 (功能描述:通过进程号杀死进程 选项 -9 表示强迫进程立即停止)
killall 进程名称 (功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)

操作

  1. 打开多几个终端 输入 ps -ef | grep sshd
    image

  2. 输入 kill 5362 杀死这个终端
    image

  3. 如果输入 killall sshd 会杀死全部远程连接进程(包括守护进程)
    需要进入linux终端输入 systemctl strat sshd 启动远程连接进程

7.10.3 pstree 查看进程树

语法

pstree [选项] (选项 -p 显示进程的PID -u 显示进程的所属用户)

操作

  1. pstree是插件,需要提前按装 输入 yum install pstree

  2. 输入 pstree 查看进程 pstree | less分页查看
    image

  3. 输入 pstree -p | less 显示进程的PID
    image

  4. 输入 pstree -u | less 显示进程的所属用户
    image

7.10.4 top 实时监控系统进程状态

语法

top [选项]

选项说明

选项 功能
-d 秒数 指定 top 命令每隔几秒更新。默认是 3 秒在 top 命令的交互模式当中可以执行的命令:
-i 使 top 不显示任何闲置或者僵死进程。
-p 通过指定监控进程 ID 来仅仅监控某个进程的状态。

操作说明

操作 功能
P 以 CPU 使用率排序,默认就是此项
M 以内存的使用率排序
N 以 PID 排序
q 退出 top

查询结果字段解释

image

第一行信息为任务队列信息

内容 说明
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 作为缓存的交互分区的大小

操作

  1. 一秒刷新一次
    [root@hadoop101 atguigu]# top -d 1

  2. 使 top 不显示任何闲置或者僵死进程。
    [root@hadoop101 atguigu]# top -i

  3. 通过指定监控进程 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
image

输入 netstat -nlp | less
image

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 分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。

操作

  1. 输入 crontab -e 打开编辑定时任务界面
    填入 */1 * * * * echo "hello,world" >> /root/hello
    每隔 1 分钟,向/root/hello 文件中添加一个 hello,world 的数字
    image

  2. 输入 ls 查看,没有hello文件会自动创建一个
    image

  3. 输入 tail -f hello 实时查看变化
    image

  4. 输入 crontab -l 查询 crontab 任务
    image

  5. 输入 crontab -r 删除当前用户所有的 crontab 任务
    image

标签:文件,常用,查看,命令,第七章,进程,root,目录,输入
From: https://www.cnblogs.com/mr155/p/16975792.html

相关文章

  • Java执行操作系统命令-Process抽象类(3)-cmd、bash
    序章在前面两篇随笔中,提到了添加下面的前缀才可以执行命令:Windows:cmd/CLinux:/bin/bash-c本文介绍这两个命令。ben发布于博客园 Windows之cmdcmd即cmd.exe。查......
  • Linux中进程管理命令
    1.PS命令,用于报告当前系统的进程状态的命令ps-ef显示所有详细的进程信息-e列出程序时,显示每个程序所使用的环境变量-f显示UIDPID......
  • Java执行操作系统命令-Process抽象类(2)(Linux)
    Java820.04.1-UbuntuEclipseVersion:2022-09(4.25.0)-- 前一篇是在Windows上执行命令,本篇介绍在Linux系统中执行命令。测试命令:ls、cd、pwd 测试代码Proce......
  • .Net Core 三个常用的生命周期(transient/scope/singleton)
    1、单例(AddSingleton:注入一次,一直有效)区别:服务在第一次请求时被创建,后边再次请求都会沿用这个已创建的服务。2、作用域(AddScoped:在一定的区域内有效)区别:服......
  • Matlab常用函数
    1、算数运算符符号角色更多信息+加法plus+一元加法uplus-减法minus-一元减法uminus.*按元素乘法times*矩阵乘法mtimes.......
  • JVM常用调优参数
    目录JVM内存模型及常用参数参数解释垃圾收集器Serial收集器(-XX:+UseSerialGC-XX:+UseSerialOldGC)ParallelScavenge收集器(-XX:+UseParallelGC-XX:+UseParallelOldGC)P......
  • js 中常用函数汇总(含示例)
    〇、前言js在日常开发中还是比较常用的,本文将常用的js方法简单汇总一下,希望对你我有一点帮助。一、重复/延迟操作1.设置固定时间间隔,重复执行(setInterval(funcRef,......
  • 20个Linux命令
    1查看目录以及权限在windows中,使用dir查看当前目录中文件。在Linux中使用ls(list)查看当前目录文件。windows中的dir,如下图所示在Linux中,通常使用ls-l列出,其中可......
  • git 基本操作命令笔记
    1.分支操作创建分支:gitbranch(branchname)切换分支命令:gitcheckout(branchname)获取远程所有分支:  gitfetch查看所有远程分支: gitbranch-r创建与远程......
  • PVE虚拟平台常用简明操作,三分钟搞定虚拟机更换安装配置
    ProxmoxVirtualEnvironment是一个基于QEMU/KVM和LXC的开源服务器虚拟化管理解决方案,本文简称PVE,与之相类似的虚拟化平台是VMWARE的ESXi虚拟平台,相较于商业产品ESXi虚拟平......