当前位置: 首页 > news >正文

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初识

  1. Linux创始人: 林纳斯 托瓦兹

  2. Linux系统的组成如下:

  • Linux系统内核:内核提供系统最核心的功能,如:调度CPU、调度内存、调度文件系统、调度网络通讯、调度IO等。
  • 系统级应用程序:系统级应用程序,可以理解为出厂自带程序,可供用户快速上手操作系统,如:文件管理器、任务管理器、图片查看、音乐播放等。

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

在这里插入图片描述

Linux基础命令

Linux目录结构

  1. 树形结构:Linux只有一个根目录/

在这里插入图片描述

  1. Linux系统中,路径之间的层级时使用:/来表示:/usr/local/hello.txt,开头斜杠表示根目录,后面的斜杠表示层级关系。
  2. 在windows中,使用:\【反斜杠】来表示:D:\data\work\hello.txt

Linux命令基础

  1. 命令行:以纯字符的形式操作系统
  2. 命令:即Linux程序,一个命令就是一个Linux程序

在这里插入图片描述

  1. 基础格式:[]表示可选

在这里插入图片描述
command: 命令本身
-options:[可选,非必填]命令的一些选项,可以通过选项控制命令的行为细节
parameter:[可选,非必填]命令的参数,多数用于命令的指向目标等

ls -l /home/it:ls是命令本身,-l是选项。/home/it是参数

ls:列出当前工作目录下的内容,默认home目录

  1. lsit files:ls --help
  2. .开头的,表示是Linux系统的隐藏文件/文件夹(只要以.开头,就能自动隐藏),只有通过ls -a,才能看到这些隐藏的文件/文件夹。
  3. ls -l:以列表(竖向排列)的形式展示内容,并展示更多信息
  4. 写法:ls -al/-la/-a -l

在这里插入图片描述

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

cd:切换目录

  1. change directory
  2. 无需选项,只有参数
  3. 无参数,默认回到home目录

pwd:查看当前工作目录

  1. print work directory
  2. 无选项,无参数
  3. 绝对路径:以根目录为起点,描述路径的一种写法,路径描述以/开头
  4. 相对路径:以当前目录为起点,描述路径的一种写法,路径描述无需以/开头
  5. 特殊路径符:
  • .表示当前目录
  • ..表示上级目录
  • ~表示home目录

在这里插入图片描述
在这里插入图片描述

mkdir:创建文件夹(目录创建)

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

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

在这里插入图片描述

touch:创建文件

  1. touch命令无选项,参数必填,表示要创建的文件路径,相对、绝对、特殊路径符均可以使用

cat:查看文件内容【全部显示】

  1. cat同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用

more:查看文件内容【支持翻页】

  1. 同cat不同的是:
    cat是直接将内容全部显示出来
    more支持翻页,如果文件内容过多,可以一页页的展示
  2. 同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用。
  3. 在查看的过程中,通过空格翻页,通过q退出查看。

cp:复制文件文件夹

  1. cp [-r] 参数1 参数2
  2. -r选项,可选,用于复制文件夹使用,表示递归
  3. 参数1,Linux路径,表示被复制的文件或文件夹
  4. 参数2,Linux路径,表示要复制去的地方
  5. 复制文件夹,必须使用-r选项,否则不会生效

mv:移动文件或文件夹

  1. 无选项,只有两个参数
  2. 参数1,Linux路径,表示被移动的文件或文件夹
  3. 参数2,Linux路径,表示要移动去的地方,如果目标不存在,则可实现改名,确保目标存在【如果参数2是路径的话,后面一定要加/

在这里插入图片描述

在这里插入图片描述

rm:删除文件、文件夹

  1. rm [-r -f] 参数1 参数2 …… 参数n
  2. 同cp命令一样,-r选项用于删除文件夹
  3. -f表示force,强制删除(不会弹出提示确认信息),普通用户删除内容不会弹出提示,只有root管理员用户删除内容会有提示,所以一般普通用户用不到-f选项
  4. 参数1、参数2、…、参数N 表示要删除的文件或文件夹路径,按照空格隔开
  5. rm命令支持通配符 *,用来做模糊匹配
  • 符号* 表示通配符,即匹配任意内容(包含空),
  • test*,表示匹配任何以test开头的内容
  • *test,表示匹配任何以test结尾的内容
  • *test*,表示匹配任何包含test的内容
  1. 切换root用户:su -root
  2. 请千万千万不要在root管理员用户下执行:rm -rf / 、 rm -rf /*,相当于windows的c盘格式化!!!

which:查找命令的程序文件

  1. 我们在前面学习的Linux命令,其实它们的本体就是一个个的二进制可执行程序。和Windows系统中的.exe文件,是一个意思。
  2. 我们可以通过which命令,查看所使用的一系列命令的程序文件存放在哪里

在这里插入图片描述

find:查找指定文件

  1. find 起始路径 -name "被查找文件名"
  2. find / -name “test”:查找文件名叫做test的文件,从根目录开始搜索
  3. 文件名查找 :被查找文件名,支持使用通配符 * 来做模糊查询。
  • 符号* 表示通配符,即匹配任意内容(包含空)
  • test*,表示匹配任何以test开头的内容
  • *test,表示匹配任何以test结尾的内容
  • *test*,表示匹配任何包含test的内容
  1. 文件大小查找: find 起始路径 -size +|- [kMG]
  • +、- 表示大于和小于
  • n表示大小数字
  • kMG表示大小单位,k(小写字母)表示kb,M表示MB,G表示GB
  • 查找小于10KB的文件: find / -size -10k

grep:通过关键字过滤文件行文件内容

  1. grep [-n] 关键字 文件路径
  • 选项-n,可选,表示在结果中显示匹配的行的行号。
  • 参数,关键字,必填,表示过滤的关键字,带有空格或其它特殊符号,建议使用””将关键字包围起来
  • 参数,文件路径,必填,表示要过滤内容的文件路径,可作为内容输入端口

在这里插入图片描述

wc:统计内容数量

  1. wc [-c -m -l -w] 文件路径
  • 选项,-l,统计行数
  • 选项,-m,统计字符数量
  • 选项,-c,统计bytes数量量
  • 选项,-w,统计单词数量
  • 参数,文件路径,被统计的文件,可作为内容输入端口

管道符 |:将管道符左边命令的结果,作为右边命令的输入

组合使用,过滤文件

在这里插入图片描述在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

echo:命令行内输出指定内容

  1. echo "输出的内容"
  • 无需选项,只有一个参数,表示要输出的内容,复杂内容可以用” ”包围。
  • 带有空格或\等特殊符号,建议使用双引号包围。因为不包围的话,空格后很容易被识别为参数2,尽管echo不受影响,但是要养成习惯。

反引号`

本意是想,输出当前的工作路径,但是pwd被作为普通字符输出了。

我们可以通过将命令用反引号(通常也称之为飘号)将其包围,被`包围的内容,会被作为命令执行,而非普通字符

在这里插入图片描述

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

在这里插入图片描述

tail:查看文件尾部内容,跟踪文件的最新更改

  1. tail [-f -num] Linux路径
  • 参数,Linux路径,表示被跟踪的文件路径
  • 选项,-f,表示持续跟踪
  • 选项, -num,表示,查看尾部多少行,*
  • 执行命令:tail,可以看到,此命令一直阻塞在那里。这是因为tail默认从标准输入(stdin)读取数据,而不是从文件读取。

vi/vim:编辑器完成文件编辑工作

  1. visual interface
  2. vi是命令行下对文本文件进行编辑的绝佳选择。
  3. vim 是 vi 的加强版本,兼容 vi 的所有指令,不仅能编辑文本,而且还具有 shell 程序编辑的功能,可以不同颜色的字体来辨别语法的正确性,极大方便了程序的设计和编辑性。
  4. vi/vim编辑器的三种模式:
  • 命令模式(Command mode)
    命令模式下,所敲的按键编辑器都理解为命令,以命令驱动执行不同的功能。
    此模型下,不能自由进行文本编辑。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

在这里插入图片描述

  1. 如果文件路径表示的文件不存在,那么此命令会用于编辑新文件。

总结

  1. 任何命令都支持:--help 选项, 可以通过这个选项,查看命令的帮助。

在这里插入图片描述

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

在这里插入图片描述

Linux用户和权限

认知root用户

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

用户和用户组管理

  1. Linux系统中可以:配置多个用户、配置多个用户组、用户可以加入多个用户组中。
  2. Linux中关于权限的管控级别有2个级别,分别是:针对用户的权限控制、针对用户组的权限控制。比如,针对某文件,可以控制用户的权限,也可以控制用户组的权限。

用户组

  1. 以下命令需root用户执行
  2. 创建用户组:groupadd 用户组名
  3. 删除用户组:groupdel 用户组名

用户

  1. useradd [-g -d] 用户名
  • 选项:-g指定用户的组,不指定-g,会创建同名组并自动加入,指定-g需要组已经存在,如已存在同名组,必须使用-g
  • 选项:-d指定用户HOME路径,不指定,HOME目录默认在:/home/用户名

在这里插入图片描述

  1. 删除用户:userdel [-r] 用户名
  • 选项:-r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留
  1. 查看用户所属组:id [用户名]
  • 参数:用户名,被查看的用户,如果不提供则查看自身
  1. 修改用户所属组:usermod -aG 用户组 用户名,将指定用户加入指定用户组,但不会退出原来的组

  2. 查看当前系统中有哪些用户:getent passwd

  • 用户名:密码(x):用户ID:组ID:描述信息(无用):HOME目录:执行终端(默认bash)

在这里插入图片描述

  1. 查看当前系统中有哪些用户组:getent group
    包含3份信息,组名称:组认证(显示为x):组ID
    在这里插入图片描述

查看权限控制信息

  1. 序号1,表示文件、文件夹的权限控制信息
    序号2,表示文件、文件夹所属用户
    序号3,表示文件、文件夹所属用户组
    在这里插入图片描述

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

  3. 针对文件、文件夹的不同,rwx的含义有细微差别

  • r,可读,针对文件可以查看文件内容:针对文件夹,可以查看文件夹内容,如ls命令
  • w,可写,针对文件表示可以修改此文件:针对文件夹,可以在文件夹内:创建、删除、改名等操作
  • x,可执行,针对文件表示可以将文件作为程序执行:针对文件夹,表示可以更改工作目录到此文件夹,即cd进入

chmod:修改文件、文件夹的权限信息

  1. 只有文件、文件夹的所属用户或root用户可以修改。
  2. chmod [-R] 权限 文件或文件夹
  • 选项:-R,对文件夹内的全部内容应用同样的操作
  1. chmod u=rwx,g=rx,o=x hello.txt :将文件权限修改为:rwxr-x–x
    其中:u表示user所属用户权限,g表示group组权限,o表示other其它用户权限
  2. chmod -R u=rwx,g=rx,o=x test:将文件夹test以及文件夹内全部内容权限设置为:rwxr-x–x
  3. 权限的数字序号:
    权限可以用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:修改文件、文件夹的所属用户和用户组

  1. 普通用户无法修改所属为其它用户或组,所以此命令只适用于root用户执行
  2. chown [-R] [用户][:][用户组] 文件或文件夹
  • 选项,-R,同chmod,对文件夹内全部内容应用相同规则
  • 选项,用户,修改所属用户
  • 选项,用户组,修改所属用户组
  • :用于分隔用户和用户组
  1. 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使用操作

各类小技巧快捷键

  1. ctrl + c 强制停止
  2. ctrl + d 退出或登出,不能用于退出vi/vim
  3. 可以通过history命令,查看历史输入过的命令

在这里插入图片描述
4. !命令前缀,自动执行上一次匹配前缀的命令

在这里插入图片描述

  1. ctrl + r,输入内容去匹配历史命令:回车键可以直接执行;键盘左右键,可以得到此命令(不执行)
  2. ctrl + a,跳到命令开头
  3. ctrl + e,跳到命令结尾
  4. ctrl + 键盘左键,向左跳一个单词
  5. ctrl + 键盘右键,向右跳一个单词
  6. 清屏:快捷键ctrl + l;或通过命令clear

软件安装

  1. Linux命令行内的”应用商店”,Centos使用yum命令安装软件,Ubuntu使用apt管理器,需要root权限,需要联网。
  2. yum:RPM包软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题。
  3. yum [-y] [install | remove | search] 软件名称,-y表示自动确认,无需手动确认安装或卸载过程
  4. apt用法和yum一致:apt [-y] [install | remove | search] 软件名称
  5. 运行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命令

  1. Linux系统很多软件(内置或第三方)均支持使用systemctl命令控制:启动、停止、开机自启

  2. 能够被systemctl管理的软件,一般也称之为:服务

  3. systemctl start | stop | status | enable | disable 服务名
    start 启动
    stop 关闭
    status 查看状态
    enable 开启开机自启
    disable 关闭开机自启

  4. 系统内置的服务比较多,比如:
    NetworkManager,主网络服务
    network,副网络服务
    firewalld,防火墙服务(ubuntu中叫做ufw)
    sshd,ssh服务(远程登录Linux使用的就是这个服务)

  5. 系统内置服务均可被systemctl控制;第三方软件,如果自动注册了可以被systemctl控制;如果没有自动注册,可以手动注册。
    例如:

yum install -y ntp 安装ntp软件
可以通过ntpd服务名,配合systemctl进行控制yum install -y httpd 安装apache服务器软件
可以通过httpd服务名,配合systemctl进行控制

ln命令软连接

  1. 在系统中创建软链接,可以将文件、文件夹链接到其它位置。类似Windows系统中的《快捷方式》
  2. 语法:ln -s 参数1 参数2
  • -s选项,创建软连接
  • 参数1:被链接的文件或文件夹
  • 参数2:要链接去的目的地
  1. cat参数1或者参数2,均可以查看参数1的文件内容

日期、时区

  1. 通过date命令可以在命令行中查看系统的时间
  2. 语法: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 到现在的秒数
  1. 按照2022-01-01的格式显示日期:date +%Y-%m-%d
  2. 按照2022-01-01 10:00:00的格式显示日期:date ”+%Y-%m-%d %H:%M:%S“ 【由于中间带有空格,所以使用双引号包围格式化字符串,作为整体】
  3. -d选项,可以按照给定的字符串显示日期,一般用于日期计算
  • year年
  • month月
  • day天
  • hour小时
  • minute分钟
  • second秒

在这里插入图片描述

IP地址、主机名

  1. 查看IP地址:ifconfig
  2. 查看主机名:hostname
  3. 修改主机名:hostnamectl set-hostname 主机名
  4. 域名解析

在这里插入图片描述

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

这样就可以利用主机名远程连接该系统
在这里插入图片描述

虚拟机配置固定IP

当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。

DHCP:动态获取IP地址,即每次重启设备后都会获取一次,可能导致IP地址频繁变更

原因1:办公电脑IP地址变化无所谓,但是我们要远程连接到Linux系统,如果IP地址经常变化我们就要频繁修改适配很麻烦

原因2:在刚刚我们配置了虚拟机IP地址和主机名的映射,如果IP频繁更改,我们也需要频繁更新映射关系

综上所述,我们需要IP地址固定下来,不要变化了。

配置固定IP需要2个大步骤:

  1. 在VMware Workstation(或Fusion)中配置IP地址网关和网段(IP地址的范围)

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  1. 在Linux系统中手动修改配置文件,固定IP

使用vim编辑/etc/sysconfig/network-scripts/ifcfg-ens33文件,填入如下内容

在这里插入图片描述
执行:systemctl restart network 重启网卡,执行ifconfig即可看到ip地址固定为192.168.88.130了

在这里插入图片描述

ping命令:检查指定的网络服务器是否是可联通状态

  1. ping [-c num] IP或者主机名
  • 选项:-c,检查的次数,不使用-c选项,将无限次数持续检查

wget:非交互式的文件下载器,可以在命令行内下载网络文件

  1. wget [-b] url
  • 选项:-b,可选,后台下载,会将日志写入到当前工作目录的wget-log文件
  • 通过tail命令可以监控后台下载进度:tail -f wget-log【-f,表示持续跟踪】

curl:发送http网络请求,可用于下载文件、获取信息等

  1. curl [-O] url
  • 选项:-O用于下载文件,当url是下载链接时,可以使用此选项保存文件

端口管理

  1. Linux系统是一个超大号小区,可以支持65535个端口,这6万多个端口分为3类进行使用:
  • 公认端口:1~1023,通常用于一些系统内置或知名程序的预留使用,如SSH服务的22端口,HTTPS服务的443端口。非特殊需要,不要占用这个范围的端口
  • 注册端口:1024~49151,通常可以随意使用,用于松散的绑定一些程序\服务
  • 动态端口:49152~65535,通常不会固定绑定程序,而是当程序对外进行网络链接时,用于临时使用。
  1. 使用nmap命令,安装nmap:yum -y install nmap
    语法:nmap 被查看的IP地址,查看被暴露的端口

在这里插入图片描述

  1. netstat命令,查看指定端口的占用情况:netstat -anp | grep 端口号
    安装netstat:yum -y install net-tools
    【0.0.0.0也可表示本机】
    在这里插入图片描述

进程管理

  1. 程序运行在操作系统中,是被操作系统所管理的。为管理运行的程序,每一个程序在运行的时候,便被操作系统注册为系统中的一个:进程,并会为每一个进程都分配一个独有的:进程ID(进程号)
  2. 查看进程:ps [-e -f]
  • 选项:-e,显示出全部的进程
  • 选项:-f,以完全格式化的形式展示信息(展示全部信息)
  • 一般来说,固定用法就是: ps -ef 列出全部进程的全部信息
  • 从左到右分别是:

UID:进程所属的用户ID PID:进程的进程号ID
PPID:进程的父ID(启动此进程的其它进程)
C:此进程的CPU占用率(百分比)
STIME:进程的启动时间
TTY:启动此进程的终端序号,如显示?,表示非终端启动
TIME:进程占用CPU的时间
CMD:进程对应的名称或启动路径或启动命令

在这里插入图片描述

  1. ps -ef | grep tail,即可准确的找到tail命令的信息
    过滤不仅仅过滤名称,进程号,用户ID等等,都可以被grep过滤哦
    如:ps -ef | grep 30001,过滤带有30001关键字的进程信息**(一般指代过滤30001进程号)**

  2. 关闭进程:kill [-9] 进程ID

  • -9,表示强制关闭进程。不使用此选项会向进程发送信号要求其关闭,但是否关闭看进程自身的处理机制。

系统资源占用

  1. 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选项启动),可以用以下交互式命令进行控制

在这里插入图片描述

磁盘信息监控

  1. df命令,可以查看硬盘的使用情况
  2. 语法:df [-h]
  • 选项:-h,以更加人性化的单位显示

在这里插入图片描述
3. 使用iostat查看CPU、磁盘的相关信息。语法:iostat [-x] [num1] [num2]

  • 选项:-x,显示更多信息
  • num1:数字,刷新间隔,num2:数字,刷新几次

rKB/s: 每秒发送到设备的读取请求数
wKB/s: 每秒发送到设备的写入请求数
%util: 磁盘利用率

在这里插入图片描述

网络状态监控

  1. 可以使用sar命令查看网络的相关统计(sar命令非常复杂,这里仅简单用于统计网络)
  2. 语法:sar -n DEV num1 num2
  • 选项:-n,查看网络,DEV表示查看网络接口
  • num1:刷新间隔(不填就查看一次结束),num2:查看次数(不填无限次数)

rxpck/s 每秒钟接受的数据包
txpck/s 每秒钟发送的数据包

在这里插入图片描述

环境变量

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

    等等一系列信息,用于辅助系统在运行的时候从环境变量中获取关键信息
    在这里插入图片描述
  4. 无论当前工作目录是什么,都能执行cd这个命令程序,这个就是借助环境变量中:PATH这个项目的值来做到的。

PATH记录了系统执行任何命令的搜索路径,如上图记录了(路径之间以:隔开): /usr/local/bin
/usr/bin
/usr/local/sbin
/usr/sbin
/home/itheima/.local/bin
/home/itheima/bin
当执行任何命令,都会按照顺序,从上述路径中搜索要执行的程序的本体 比如执行cd命令,就从第二个目录/usr/bin中搜索到了cd命令,并执行

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

  1. 自行设置环境变量
  • 临时设置,语法:export 变量名=变量值
  • 永久生效
    针对当前用户生效,配置在当前用户的: ~/.bashrc文件中,
export  MYNAME=gyy
echo $MYNAME

针对所有用户生效,配置在系统的: /etc/profile文件中

  • 两种永久生效配置后,均需要通过语法:source 配置文件,进行立刻生效,或重启Linux主机生效

上传、下载

  1. rz、sz命令需要安装,可以通过:yum -y install lrzsz,即可安装。
  2. 下载命令:sz 文件名
  3. 上传命令:rz,即可弹出文件

压缩、解压

  1. 市面上有非常多的压缩格式

zip格式:Linux、Windows、MacOS,常用
7zip:Windows系统常用
rar:Windows系统常用
tar:Linux、MacOS常用
gzip:Linux、MacOS常用

  1. Linux和Mac系统常用有2种压缩格式,后缀名分别是:
    .tar,称之为tarball,归档文件,即简单的将文件组装到一个.tar的文件内,并没有太多文件体积的减少,仅仅是简单的封装
    .gz,也常见为.tar.gz,gzip格式压缩文件,即使用gzip压缩算法将文件压缩到一个文件内,可以极大的减少压缩后的体积
    针对这两种格式,使用tar命令均可以进行压缩和解压缩的操作

  2. 语法:tar [-c -v -x -f -z -C ] 参数1 参数2 ……参数N

-c,创建压缩文件,用于压缩模式
-v,显示压缩、解压过程,用于查看进度
-x,解压模式
-f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个
-z,gzip模式,不使用-z就是普通的tarball格式
-C,选择解压的目的地,用于解压模式

  1. 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 选项,必须在选项位最后一个

  1. 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 选项单独使用,和解压所需的其它参数分开

  1. 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文件内

  1. unzip 命令解压文件
  • 语法:unzip [-d] 参数
  • -d,指定要解压去的位置,同tar的-C选项
  • 参数,被解压的zip压缩包文件
  • unzip test.zip,将test.zip解压到当前目录
  • unzip test.zip -d /home/itheima,将test.zip解压到指定文件夹内(/home/itheima)
http://www.dtcms.com/a/617910.html

相关文章:

  • 永恒之蓝内网横向渗透:原理详解+telnet法渗透实践(CVE-2017-0144)
  • 购物网站答辩ppt怎么做做购物平台网站 民治
  • 【Linux】Linux编译器-gcc/g++使用和gcc具体编译过程以及编译选项的小插曲
  • flume单机版安装
  • C++篇(17)哈希拓展学习
  • 做建筑材料的网站wordpress后台左侧菜单显示
  • 基于SpringBoot的热门旅游推荐系统设计与实现
  • leetcode 1513 仅含1的子串数
  • 2014网站怎么备案网站怎么做口碑
  • 【微服务】SpringBoot 整合高性能时序数据库 Apache IoTDB 实战操作详解
  • 【电路笔记】-单稳态多谐振荡器
  • Java数据结构-Map和Set-通配符?-反射-枚举-Lambda
  • 在那里能找到网站网络营销与网站推广的区别
  • 架构之路(六):把框架拉出来
  • 【Linux驱动开发】Linux SPI 通信详解:从硬件到驱动再到应用
  • 【ASP.NET进阶】Controller层核心:Action方法全解析,从基础到避坑
  • Imec实现了GaN击穿电压的记录
  • Streaming ELT with Flink CDC · Iceberg Sink
  • AI(新手)
  • 海南城乡建设厅网站百度竞价关键词查询
  • QT开发——常用控件(2)
  • 【Java架构师体系课 | MySQL篇】⑥ 索引优化实战二
  • Spring Boot、Redis、RabbitMQ 在项目中的核心作用详解
  • 做完整的网站设计需要的技术长治建立公司网站的步骤
  • 南宁京象建站公司网站建设留言板实验心得
  • AI、LLM全景图
  • pip升级已安装包方法详解
  • 【Linux日新月异(六)】CentOS 7网络命令深度解析:从传统到现代网络管理
  • LangChain 构建 AI 代理(Agent)
  • 人工智能训练师备考——3.1.1题解