Linux操作系统基础命令基础
黑马Linux零基础快速入门到精通
因为我之前学过一遍,但是时间比较久远,所以看黑马视频再复习一遍
文章目录
- 操作系统概述
- Linux初识
- Linux基础命令
- Linux目录结构
- Linux命令基础
- ls:列出当前工作目录下的内容,默认home目录
- cd:切换目录
- pwd:查看当前工作目录
- mkdir:创建文件夹(目录创建)
- touch:创建文件
- cat:查看文件内容【全部显示】
- more:查看文件内容【支持翻页】
- cp:复制文件文件夹
- mv:移动文件或文件夹
- rm:删除文件、文件夹
- which:查找命令的程序文件
- find:查找指定文件
- grep:通过关键字过滤文件行文件内容
- wc:统计内容数量
- 管道符 |:将管道符左边命令的结果,作为右边命令的输入
- echo:命令行内输出指定内容
- 反引号`
- 重定向符:>和>>,>将左侧命令的结果,覆盖写入到符号右侧指定的文件中,>>将左侧命令的结果,追加写入到符号右侧指定的文件中
- tail:查看文件尾部内容,跟踪文件的最新更改
- vi/vim:编辑器完成文件编辑工作
- 总结
- Linux用户和权限
- 认知root用户
- 用户和用户组管理
- 用户组
- 用户
- 查看权限控制信息
- chmod:修改文件、文件夹的权限信息
- chown:修改文件、文件夹的所属用户和用户组
- Linux使用操作
- 各类小技巧快捷键
- 软件安装
- systemctl命令
- ln命令软连接
- 日期、时区
- IP地址、主机名
- 虚拟机配置固定IP
- ping命令:检查指定的网络服务器是否是可联通状态
- wget:非交互式的文件下载器,可以在命令行内下载网络文件
- curl:发送http网络请求,可用于下载文件、获取信息等
- 端口管理
- 进程管理
- 系统资源占用
- 磁盘信息监控
- 网络状态监控
- 环境变量
- 上传、下载
- 压缩、解压
操作系统概述
用户使用操作系统,操作系统安排硬件干活

作用:作为用户和计算机硬件之间的桥梁,调度和管理计算机硬件进行工作。

Linux初识
-
Linux创始人: 林纳斯 托瓦兹
-
Linux系统的组成如下:
- Linux系统内核:内核提供系统最核心的功能,如:调度CPU、调度内存、调度文件系统、调度网络通讯、调度IO等。
- 系统级应用程序:系统级应用程序,可以理解为出厂自带程序,可供用户快速上手操作系统,如:文件管理器、任务管理器、图片查看、音乐播放等。

3. 内核源码:https://www.kernel.org
4. 任何人都可以获得并修改内核,并且自行集成系统级程序。提供了内核+系统级程序的完整封装,称之为Linux发行版。

Linux基础命令
Linux目录结构
- 树形结构:Linux只有一个根目录
/

- Linux系统中,路径之间的层级时使用
:/来表示:/usr/local/hello.txt,开头斜杠表示根目录,后面的斜杠表示层级关系。 - 在windows中,使用
:\【反斜杠】来表示:D:\data\work\hello.txt。
Linux命令基础
- 命令行:以纯字符的形式操作系统
- 命令:即Linux程序,一个命令就是一个Linux程序

- 基础格式:
[]表示可选

command: 命令本身
-options:[可选,非必填]命令的一些选项,可以通过选项控制命令的行为细节
parameter:[可选,非必填]命令的参数,多数用于命令的指向目标等
ls -l /home/it:ls是命令本身,-l是选项。/home/it是参数
ls:列出当前工作目录下的内容,默认home目录
- lsit files:ls --help
- 以
.开头的,表示是Linux系统的隐藏文件/文件夹(只要以.开头,就能自动隐藏),只有通过ls -a,才能看到这些隐藏的文件/文件夹。 - ls -l:以列表(竖向排列)的形式展示内容,并展示更多信息
- 写法:ls -al/-la/-a -l

- -h 表示以易于阅读的形式,列出文件大小,如K、M、G,没有单位就是B。-h选项必须要搭配 -l 一起使用
【其中前面是d的代表文件夹,-表示是一个文件】

cd:切换目录
- change directory
- 无需选项,只有参数
- 无参数,默认回到home目录
pwd:查看当前工作目录
- print work directory
- 无选项,无参数
- 绝对路径:以根目录为起点,描述路径的一种写法,路径描述以
/开头 - 相对路径:以当前目录为起点,描述路径的一种写法,路径描述无需以
/开头 - 特殊路径符:
.表示当前目录..表示上级目录~表示home目录


mkdir:创建文件夹(目录创建)
- make directory
- 参数必填,表示Linux路径,即要创建的文件夹的路径,相对路径或绝对路径均可
-p选项可选,表示自动创建不存在的父目录,适用于创建连续多层级的目录

4. 创建文件夹需要修改权限,请确保操作均在HOME目录内,不要在HOME外操作;
涉及到权限问题,HOME外无法成功

touch:创建文件
- touch命令无选项,参数必填,表示要创建的文件路径,相对、绝对、特殊路径符均可以使用
cat:查看文件内容【全部显示】
- cat同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用
more:查看文件内容【支持翻页】
- 同cat不同的是:
cat是直接将内容全部显示出来
more支持翻页,如果文件内容过多,可以一页页的展示 - 同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用。
- 在查看的过程中,通过空格翻页,通过q退出查看。
cp:复制文件文件夹
cp [-r] 参数1 参数2-r选项,可选,用于复制文件夹使用,表示递归- 参数1,Linux路径,表示被复制的文件或文件夹
- 参数2,Linux路径,表示要复制去的地方
- 复制文件夹,必须使用-r选项,否则不会生效
mv:移动文件或文件夹
- 无选项,只有两个参数
- 参数1,Linux路径,表示被移动的文件或文件夹
- 参数2,Linux路径,表示要移动去的地方,如果目标不存在,则可实现改名,确保目标存在【如果参数2是路径的话,后面一定要加/】


rm:删除文件、文件夹
rm [-r -f] 参数1 参数2 …… 参数n- 同cp命令一样,
-r选项用于删除文件夹 -f表示force,强制删除(不会弹出提示确认信息),普通用户删除内容不会弹出提示,只有root管理员用户删除内容会有提示,所以一般普通用户用不到-f选项- 参数1、参数2、…、参数N 表示要删除的文件或文件夹路径,按照空格隔开
- rm命令支持通配符
*,用来做模糊匹配
- 符号
*表示通配符,即匹配任意内容(包含空), test*,表示匹配任何以test开头的内容*test,表示匹配任何以test结尾的内容*test*,表示匹配任何包含test的内容
- 切换root用户:
su -root - 请千万千万不要在root管理员用户下执行:
rm -rf / 、 rm -rf /*,相当于windows的c盘格式化!!!
which:查找命令的程序文件
- 我们在前面学习的Linux命令,其实它们的本体就是一个个的二进制可执行程序。和Windows系统中的.exe文件,是一个意思。
- 我们可以通过which命令,查看所使用的一系列命令的程序文件存放在哪里

find:查找指定文件
find 起始路径 -name "被查找文件名"find / -name “test”:查找文件名叫做test的文件,从根目录开始搜索- 文件名查找 :被查找文件名,支持使用通配符 * 来做模糊查询。
- 符号
*表示通配符,即匹配任意内容(包含空) test*,表示匹配任何以test开头的内容*test,表示匹配任何以test结尾的内容*test*,表示匹配任何包含test的内容
- 文件大小查找:
find 起始路径 -size +|- [kMG]
- +、- 表示大于和小于
- n表示大小数字
- kMG表示大小单位,k(小写字母)表示kb,M表示MB,G表示GB
- 查找小于10KB的文件: find / -size -10k
grep:通过关键字过滤文件行文件内容
grep [-n] 关键字 文件路径
- 选项-n,可选,表示在结果中显示匹配的行的行号。
- 参数,关键字,必填,表示过滤的关键字,带有空格或其它特殊符号,建议使用
””将关键字包围起来 - 参数,文件路径,必填,表示要过滤内容的文件路径,可作为内容输入端口

wc:统计内容数量
wc [-c -m -l -w] 文件路径
- 选项,-l,统计行数
- 选项,-m,统计字符数量
- 选项,-c,统计bytes数量量
- 选项,-w,统计单词数量
- 参数,文件路径,被统计的文件,可作为内容输入端口
管道符 |:将管道符左边命令的结果,作为右边命令的输入
组合使用,过滤文件




echo:命令行内输出指定内容
echo "输出的内容"
- 无需选项,只有一个参数,表示要输出的内容,复杂内容可以用
” ”包围。 - 带有空格或
\等特殊符号,建议使用双引号包围。因为不包围的话,空格后很容易被识别为参数2,尽管echo不受影响,但是要养成习惯。
反引号`
本意是想,输出当前的工作路径,但是pwd被作为普通字符输出了。
我们可以通过将命令用反引号(通常也称之为飘号)将其包围,被`包围的内容,会被作为命令执行,而非普通字符

重定向符:>和>>,>将左侧命令的结果,覆盖写入到符号右侧指定的文件中,>>将左侧命令的结果,追加写入到符号右侧指定的文件中

tail:查看文件尾部内容,跟踪文件的最新更改
- tail [-f -num] Linux路径
- 参数,Linux路径,表示被跟踪的文件路径
- 选项,-f,表示持续跟踪
- 选项, -num,表示,查看尾部多少行,*
- 执行命令:tail,可以看到,此命令一直阻塞在那里。这是因为tail默认从标准输入(stdin)读取数据,而不是从文件读取。
vi/vim:编辑器完成文件编辑工作
- visual interface
- vi是命令行下对文本文件进行编辑的绝佳选择。
- vim 是 vi 的加强版本,兼容 vi 的所有指令,不仅能编辑文本,而且还具有 shell 程序编辑的功能,可以不同颜色的字体来辨别语法的正确性,极大方便了程序的设计和编辑性。
- vi/vim编辑器的三种模式:
- 命令模式(Command mode)
命令模式下,所敲的按键编辑器都理解为命令,以命令驱动执行不同的功能。
此模型下,不能自由进行文本编辑。



- 输入模式(Insert mode)
也就是所谓的编辑模式、插入模式。
此模式下,可以对文件内容进行自由编辑。 - 底线命令模式(Last line mode)
以:开始,通常用于文件的保存、退出。

- 如果文件路径表示的文件不存在,那么此命令会用于编辑新文件。
总结
- 任何命令都支持:
--help选项, 可以通过这个选项,查看命令的帮助。

- 查看命令的详细手册,可以通过
man(manual, 手册)命令查看

Linux用户和权限
认知root用户
- 在Linux系统中,拥有最大权限的账户名为:root(超级管理员)
- 普通用户的权限,一般在其HOME目录内是不受限的
- 一旦出了HOME目录,大多数地方,普通用户仅有只读和执行权限,无修改权限
- 切换账户:su [-] [用户名]
-符号是可选的,表示是否在切换用户后加载环境变量,建议带上- 参数:用户名,表示要切换的用户,用户名也可以省略,省略表示切换到root
- 切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键:ctrl + d
- sudo命令,为普通的命令授权,临时以root身份执行。
- 在其它命令之前,带上sudo,即可为这一条命令临时赋予root授权
- 但是并不是所有的用户,都有权利使用sudo,我们需要为普通用户配置sudo认证
- 为普通用户配置sudo认证
- 换到root用户,执行visudo命令,会自动通过vi编辑器打开:/etc/sudoers
- 在文件的最后添加,其中最后的NOPASSWD:ALL 表示使用sudo命令,无需输入密码

- 最后通过 wq 保存
用户和用户组管理
- Linux系统中可以:配置多个用户、配置多个用户组、用户可以加入多个用户组中。
- Linux中关于权限的管控级别有2个级别,分别是:针对用户的权限控制、针对用户组的权限控制。比如,针对某文件,可以控制用户的权限,也可以控制用户组的权限。
用户组
- 以下命令需root用户执行
- 创建用户组:groupadd 用户组名
- 删除用户组:groupdel 用户组名
用户
- useradd [-g -d] 用户名
- 选项:
-g指定用户的组,不指定-g,会创建同名组并自动加入,指定-g需要组已经存在,如已存在同名组,必须使用-g - 选项:
-d指定用户HOME路径,不指定,HOME目录默认在:/home/用户名

- 删除用户:
userdel [-r] 用户名
- 选项:-r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留
- 查看用户所属组:
id [用户名]
- 参数:用户名,被查看的用户,如果不提供则查看自身
-
修改用户所属组:
usermod -aG 用户组 用户名,将指定用户加入指定用户组,但不会退出原来的组 -
查看当前系统中有哪些用户:
getent passwd
- 用户名:密码(x):用户ID:组ID:描述信息(无用):HOME目录:执行终端(默认bash)

- 查看当前系统中有哪些用户组:
getent group
包含3份信息,组名称:组认证(显示为x):组ID

查看权限控制信息
-
序号1,表示文件、文件夹的权限控制信息
序号2,表示文件、文件夹所属用户
序号3,表示文件、文件夹所属用户组

-
序号1的10个位置含义:drwxr-xr-x,表示:
这是一个文件夹,首字母d表示
所属用户(序号2)的权限是:有r有w有x,rwx
所属用户组(序号3)的权限是:有r无w有x,r-x (-表示无此权限)
其它用户的权限是:有r无w有x,r-x
可读可写可执行

-
针对文件、文件夹的不同,rwx的含义有细微差别
- r,可读,针对文件可以查看文件内容:针对文件夹,可以查看文件夹内容,如ls命令
- w,可写,针对文件表示可以修改此文件:针对文件夹,可以在文件夹内:创建、删除、改名等操作
- x,可执行,针对文件表示可以将文件作为程序执行:针对文件夹,表示可以更改工作目录到此文件夹,即cd进入
chmod:修改文件、文件夹的权限信息
- 只有文件、文件夹的所属用户或root用户可以修改。
chmod [-R] 权限 文件或文件夹
- 选项:-R,对文件夹内的全部内容应用同样的操作
chmod u=rwx,g=rx,o=x hello.txt:将文件权限修改为:rwxr-x–x
其中:u表示user所属用户权限,g表示group组权限,o表示other其它用户权限chmod -R u=rwx,g=rx,o=x test:将文件夹test以及文件夹内全部内容权限设置为:rwxr-x–x- 权限的数字序号:
权限可以用3位数字来代表,第一位数字表示用户权限,第二位表示用户组权限,第三位表示其它用户权限。
数字的细节如下:r记为4,w记为2,x记为1,可以有:
0:无任何权限, 即 —
1:仅有x权限, 即 --x
2:仅有w权限 即 -w-
3:有w和x权限 即 -wx
4:仅有r权限 即 r–
5:有r和x权限 即 r-x
6:有r和w权限 即 rw-
7:有全部权限 即 rwx
chmod 751 hello.txt 《=》 chmod u=rwx,g=rx,o=x hello.txt
chown:修改文件、文件夹的所属用户和用户组
- 普通用户无法修改所属为其它用户或组,所以此命令只适用于root用户执行
chown [-R] [用户][:][用户组] 文件或文件夹
- 选项,-R,同chmod,对文件夹内全部内容应用相同规则
- 选项,用户,修改所属用户
- 选项,用户组,修改所属用户组
:用于分隔用户和用户组
- chown root hello.txt,将hello.txt所属用户修改为root
chown :root hello.txt,将hello.txt所属用户组修改为root
chown root:itheima hello.txt,将hello.txt所属用户修改为root,用户组修改为itheima
chown -R root test,将文件夹test的所属用户修改为root并对文件夹内全部内容应用同样规则
Linux使用操作
各类小技巧快捷键
- ctrl + c 强制停止
- ctrl + d 退出或登出,不能用于退出vi/vim
- 可以通过history命令,查看历史输入过的命令

4. !命令前缀,自动执行上一次匹配前缀的命令

- ctrl + r,输入内容去匹配历史命令:回车键可以直接执行;键盘左右键,可以得到此命令(不执行)
- ctrl + a,跳到命令开头
- ctrl + e,跳到命令结尾
- ctrl + 键盘左键,向左跳一个单词
- ctrl + 键盘右键,向右跳一个单词
- 清屏:快捷键ctrl + l;或通过命令clear
软件安装
- Linux命令行内的”应用商店”,Centos使用yum命令安装软件,Ubuntu使用apt管理器,需要root权限,需要联网。
- yum:RPM包软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题。
yum [-y] [install | remove | search] 软件名称,-y表示自动确认,无需手动确认安装或卸载过程- apt用法和yum一致:
apt [-y] [install | remove | search] 软件名称 - 运行yum -有install wget时,若出现报错
Loaded plugins: fastestmirror, langpacks
Loading mirror speeds from cached hostfile
Could not retrieve mirrorlist http://mirrorlist.centos.org/?release=7&arch=x86_64&repo=os&infra=stock error was
14: curl#6 - "Could not resolve host: mirrorlist.centos.org; Unknown error"
则说明镜像有问题,更换为阿里云镜像即可,操作如下
cd /etc/yum.repos.d# 备份原 repo 文件
sudo mv CentOS-Base.repo CentOS-Base.repo.backup# 下载阿里云的 repo 文件
sudo wget -O CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo# 清除缓存并重建
sudo yum clean all
sudo yum makecache#然后重试安装:
sudo yum -y install wget
systemctl命令
-
Linux系统很多软件(内置或第三方)均支持使用systemctl命令控制:启动、停止、开机自启
-
能够被systemctl管理的软件,一般也称之为:服务
-
systemctl start | stop | status | enable | disable 服务名
start 启动
stop 关闭
status 查看状态
enable 开启开机自启
disable 关闭开机自启 -
系统内置的服务比较多,比如:
NetworkManager,主网络服务
network,副网络服务
firewalld,防火墙服务(ubuntu中叫做ufw)
sshd,ssh服务(远程登录Linux使用的就是这个服务) -
系统内置服务均可被systemctl控制;第三方软件,如果自动注册了可以被systemctl控制;如果没有自动注册,可以手动注册。
例如:
yum install -y ntp 安装ntp软件
可以通过ntpd服务名,配合systemctl进行控制yum install -y httpd 安装apache服务器软件
可以通过httpd服务名,配合systemctl进行控制
ln命令软连接
- 在系统中创建软链接,可以将文件、文件夹链接到其它位置。类似Windows系统中的《快捷方式》
- 语法:
ln -s 参数1 参数2
-s选项,创建软连接- 参数1:被链接的文件或文件夹
- 参数2:要链接去的目的地
- cat参数1或者参数2,均可以查看参数1的文件内容
日期、时区
- 通过date命令可以在命令行中查看系统的时间
- 语法:date [-d] [+格式化字符串]
- -d 按照给定的字符串显示日期,一般用于日期计算
- 格式化字符串:通过特定的字符串标记,来控制显示的日期格式
- %Y 年
- %y 年份后两位数字 (00…99)
- %m 月份 (01…12)
- %d 日 (01…31)
- %H 小时 (00…23)
- %M 分钟 (00…59)
- %S 秒 (00…60)
- %s 自 1970-01-01 00:00:00 UTC 到现在的秒数
- 按照2022-01-01的格式显示日期:date
+%Y-%m-%d - 按照2022-01-01 10:00:00的格式显示日期:date
”+%Y-%m-%d %H:%M:%S“【由于中间带有空格,所以使用双引号包围格式化字符串,作为整体】 - -d选项,可以按照给定的字符串显示日期,一般用于日期计算
- year年
- month月
- day天
- hour小时
- minute分钟
- second秒

IP地址、主机名
- 查看IP地址:
ifconfig - 查看主机名:
hostname - 修改主机名:
hostnamectl set-hostname 主机名 - 域名解析

- 先查看本机的记录(私人地址本)
Windows看:C:\Windows\System32\drivers\etc\hosts
Linux看:/etc/hosts - 再联网去DNS服务器(如114.114.114.114,8.8.8.8等)询问
- 利用域名(主机名)远程连接
- 在Windows系统的:
C:\Windows\System32\drivers\etc\hosts文件中配置记录即可
这样就可以利用主机名远程连接该系统

虚拟机配置固定IP
当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。
DHCP:动态获取IP地址,即每次重启设备后都会获取一次,可能导致IP地址频繁变更
原因1:办公电脑IP地址变化无所谓,但是我们要远程连接到Linux系统,如果IP地址经常变化我们就要频繁修改适配很麻烦
原因2:在刚刚我们配置了虚拟机IP地址和主机名的映射,如果IP频繁更改,我们也需要频繁更新映射关系
综上所述,我们需要IP地址固定下来,不要变化了。
配置固定IP需要2个大步骤:
- 在VMware Workstation(或Fusion)中配置IP地址网关和网段(IP地址的范围)




- 在Linux系统中手动修改配置文件,固定IP
使用vim编辑/etc/sysconfig/network-scripts/ifcfg-ens33文件,填入如下内容

执行:systemctl restart network 重启网卡,执行ifconfig即可看到ip地址固定为192.168.88.130了

ping命令:检查指定的网络服务器是否是可联通状态
ping [-c num] IP或者主机名
- 选项:
-c,检查的次数,不使用-c选项,将无限次数持续检查
wget:非交互式的文件下载器,可以在命令行内下载网络文件
wget [-b] url
- 选项:
-b,可选,后台下载,会将日志写入到当前工作目录的wget-log文件 - 通过tail命令可以监控后台下载进度:
tail -f wget-log【-f,表示持续跟踪】
curl:发送http网络请求,可用于下载文件、获取信息等
curl [-O] url
- 选项:
-O,用于下载文件,当url是下载链接时,可以使用此选项保存文件
端口管理
- Linux系统是一个超大号小区,可以支持65535个端口,这6万多个端口分为3类进行使用:
- 公认端口:1~1023,通常用于一些系统内置或知名程序的预留使用,如SSH服务的22端口,HTTPS服务的443端口。非特殊需要,不要占用这个范围的端口
- 注册端口:1024~49151,通常可以随意使用,用于松散的绑定一些程序\服务
- 动态端口:49152~65535,通常不会固定绑定程序,而是当程序对外进行网络链接时,用于临时使用。
- 使用nmap命令,安装nmap:yum -y install nmap
语法:nmap 被查看的IP地址,查看被暴露的端口

- netstat命令,查看指定端口的占用情况:
netstat -anp | grep 端口号,
安装netstat:yum -y install net-tools
【0.0.0.0也可表示本机】

进程管理
- 程序运行在操作系统中,是被操作系统所管理的。为管理运行的程序,每一个程序在运行的时候,便被操作系统注册为系统中的一个:进程,并会为每一个进程都分配一个独有的:进程ID(进程号)
- 查看进程:
ps [-e -f]
- 选项:-e,显示出全部的进程
- 选项:-f,以完全格式化的形式展示信息(展示全部信息)
- 一般来说,固定用法就是: ps -ef 列出全部进程的全部信息
- 从左到右分别是:
UID:进程所属的用户ID PID:进程的进程号ID
PPID:进程的父ID(启动此进程的其它进程)
C:此进程的CPU占用率(百分比)
STIME:进程的启动时间
TTY:启动此进程的终端序号,如显示?,表示非终端启动
TIME:进程占用CPU的时间
CMD:进程对应的名称或启动路径或启动命令

-
ps -ef | grep tail,即可准确的找到tail命令的信息
过滤不仅仅过滤名称,进程号,用户ID等等,都可以被grep过滤哦
如:ps -ef | grep 30001,过滤带有30001关键字的进程信息**(一般指代过滤30001进程号)** -
关闭进程:
kill [-9] 进程ID
-9,表示强制关闭进程。不使用此选项会向进程发送信号要求其关闭,但是否关闭看进程自身的处理机制。
系统资源占用
- top命令查看CPU、内存使用情况,类似Windows的任务管理器。默认每5秒刷新一次,语法:直接输入top即可,按q或ctrl + c退出【类似于windows的任务管理器】

2.
PID:进程id
USER:进程所属用户
PR:进程优先级,越小越高
NI:负值表示高优先级,正表示低优先级
VIRT:进程使用虚拟内存,单位KB
RES:进程使用物理内存,单位KB SHR:进程使用共享内存,单位KB
S:进程状态(S休眠,R运行,Z僵死状态,N负数优先级,I空闲状态)
%CPU:进程占用CPU率
%MEM:进程占用内存率
TIME+:进程使用CPU时间总计,单位10毫秒
COMMAND:进程的命令或名称或程序文件路径


3. 当top以交互式运行(非-b选项启动),可以用以下交互式命令进行控制

磁盘信息监控
- df命令,可以查看硬盘的使用情况
- 语法:
df [-h]
- 选项:-h,以更加人性化的单位显示

3. 使用iostat查看CPU、磁盘的相关信息。语法:iostat [-x] [num1] [num2]
- 选项:-x,显示更多信息
- num1:数字,刷新间隔,num2:数字,刷新几次
rKB/s: 每秒发送到设备的读取请求数
wKB/s: 每秒发送到设备的写入请求数
%util: 磁盘利用率

网络状态监控
- 可以使用sar命令查看网络的相关统计(sar命令非常复杂,这里仅简单用于统计网络)
- 语法:
sar -n DEV num1 num2
- 选项:-n,查看网络,DEV表示查看网络接口
- num1:刷新间隔(不填就查看一次结束),num2:查看次数(不填无限次数)
rxpck/s 每秒钟接受的数据包
txpck/s 每秒钟发送的数据包

环境变量
- 环境变量是操作系统(Windows、Linux、Mac)在运行的时候,记录的一些关键性信息,用以辅助系统运行。
- 在Linux系统中执行:env命令,即可查看当前系统中记录的环境变量
- 环境变量是一种KeyValue型结构,即名称和值,如下图:
HOME:/home/itheima,用户的HOME路径
USER:itheima,当前的操作用户
PWD:当前工作路径
…
等等一系列信息,用于辅助系统在运行的时候从环境变量中获取关键信息

- 无论当前工作目录是什么,都能执行cd这个命令程序,这个就是借助环境变量中:PATH这个项目的值来做到的。
PATH记录了系统执行任何命令的搜索路径,如上图记录了(路径之间以:隔开): /usr/local/bin
/usr/bin
/usr/local/sbin
/usr/sbin
/home/itheima/.local/bin
/home/itheima/bin
当执行任何命令,都会按照顺序,从上述路径中搜索要执行的程序的本体 比如执行cd命令,就从第二个目录/usr/bin中搜索到了cd命令,并执行

- 在Linux系统中,
$符号被用于取”变量”的值。
环境变量记录的信息,除了给操作系统自己使用外,如果我们想要取用,也可以使用。
取得环境变量的值就可以通过语法:$ 环境变量名来取得
- 比如:
echo $PATH,就可以取得PATH这个环境变量的值,并通过echo语句输出出来。

echo ${PATH}ABC,当和其它内容混合在一起的时候,可以通过{}来标注取的变量是谁

- 自行设置环境变量
- 临时设置,语法:
export 变量名=变量值 - 永久生效
针对当前用户生效,配置在当前用户的:~/.bashrc文件中,
export MYNAME=gyy
echo $MYNAME
针对所有用户生效,配置在系统的: /etc/profile文件中
- 两种永久生效配置后,均需要通过语法:
source配置文件,进行立刻生效,或重启Linux主机生效
上传、下载
- rz、sz命令需要安装,可以通过:
yum -y install lrzsz,即可安装。 - 下载命令:
sz 文件名 - 上传命令:
rz,即可弹出文件
压缩、解压
- 市面上有非常多的压缩格式
zip格式:Linux、Windows、MacOS,常用
7zip:Windows系统常用
rar:Windows系统常用
tar:Linux、MacOS常用
gzip:Linux、MacOS常用
-
Linux和Mac系统常用有2种压缩格式,后缀名分别是:
.tar,称之为tarball,归档文件,即简单的将文件组装到一个.tar的文件内,并没有太多文件体积的减少,仅仅是简单的封装
.gz,也常见为.tar.gz,gzip格式压缩文件,即使用gzip压缩算法将文件压缩到一个文件内,可以极大的减少压缩后的体积
针对这两种格式,使用tar命令均可以进行压缩和解压缩的操作 -
语法:
tar [-c -v -x -f -z -C ] 参数1 参数2 ……参数N
-c,创建压缩文件,用于压缩模式
-v,显示压缩、解压过程,用于查看进度
-x,解压模式
-f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个
-z,gzip模式,不使用-z就是普通的tarball格式
-C,选择解压的目的地,用于解压模式
- tar压缩常用命令:
tar -cvf test.tar 1.txt 2.txt 3.txt:将1.txt 2.txt 3.txt 压缩到test.tar文件内tar -zcvf test.tar.gz 1.txt 2.txt 3.txt:将1.txt 2.txt 3.txt 压缩到test.tar.gz文件内,使用gzip模式
-z 选项如果使用的话,一般处于选项位第一个
-f 选项,必须在选项位最后一个
- tar解压常用命令:
tar -xvf test.tar:解压test.tar,将文件解压至当前目录tar -xvf test.tar -C /home/itheima:解压test.tar,将文件解压至指定目录(/home/itheima)tar -zxvf test.tar.gz -C /home/itheima:以Gzip模式解压test.tar.gz,将文件解压至指定目录(/home/itheima)
-f 选项,必须在选项组合体的最后一位
-z 选项,建议在开头位置
-C 选项单独使用,和解压所需的其它参数分开
- zip 命令压缩文件:可以使用zip命令,压缩文件为zip压缩包
-
-r,被压缩的包含文件夹的时候,需要使用-r选项,和rm、cp等命令的-r效果一致 -
zip test.zip a.txt b.txt c.txt:将a.txt b.txt c.txt 压缩到test.zip文件内 -
zip -r test.zip test itheima a.txt:将test、itheima两个文件夹和a.txt文件,压缩到test.zip文件内
- unzip 命令解压文件
- 语法:
unzip [-d] 参数 -d,指定要解压去的位置,同tar的-C选项- 参数,被解压的zip压缩包文件
unzip test.zip,将test.zip解压到当前目录unzip test.zip -d /home/itheima,将test.zip解压到指定文件夹内(/home/itheima)
