linux目录结构是树形目录结构
根目录(树根)

需要注意一下的是Linux 操作系统中只有一个根目录,而 Windows 操作系统中每个分区都有一个根目录,这点需要加以区别。
必须知道
Linux 操作系统在定位文件或目录位置时,使用斜杠“/”进行分隔(区别于 Windows 操作系统中的反斜杠“\”)
| 目录路径 | 目录作用 |
|---|---|
| /root | 系统管理员root的宿主目录 |
| /home | 普通用户的宿主目录 |
| /boot | 系统内核、启动文件存放位置 |
| /dev | 设备文件存放位置 |
| /etc | 配置文件存放位置 |
| /bin | 所有用户可执行的命令存放位置 |
| /sbin | 管理员可执行的管理命令存放位置 |
| /usr | 应用程序存放位置 |
| /var | 日志文件等存放位置 |
查看文件内容cat命令
- cat /etc/sysconfig/network-scripts/ifcfg-ens33 //配置文件中的内容,并了解第一块以太网卡的配置信息。
- cat /etc/redhat-release /proc/version // 文件的内容,前者记录了 CentOS 系统的发行版本信息,后者记录了系统内核及开发环境、时间等信息。进程;process 过程
-

但是用这个命令在长文件会看不过来
可以使用more或者是less分页

除了可以分屏查看文件内容以外,还可以结合管道符号“|”分屏查看执行命令时的输出信息,这在命令输出内容较多的情况下特别有用。 但是more 命令只能向下翻页,不能向上翻页。

查看文件内容head,tail命令 中
head -n(n为数字,行数) 文件名,用途:查看文件开头的一部分内容 (默认为10行)

用途:查看文件结尾的少部分内容 (默认为10行)
tail -n 文件名
tail -f 文件名(重要)追踪
实验一

可以查看用户账号文件/etc/passwd 开头第一行至第四行的内容

实验二
tail 命令通常用于查看系统日志(因为较新的日志记录总是添加到文件最后),以便观察网络访问、服务调试等相关信息。配合“-f”选项使用时,还可以跟踪文件尾部内容的动态更新,便于实时监控文件内容的变化


wc 命令用于统计文件内容中包含的行数、单词数、字节数等信息,使用文件名作为参数,可以同时统计多个文件

例如,Linux 操作系统中的用户账号数据保存在/etc/passwd 文件中,其中每一行记录对应一个用户,则以下操作可以统计出当前Linux 操作系统中拥有的用户账号数量

若将 wc 命令与管道符号一起使用,还可以对命令输出结果进行统计。
/etc/目录下共包含多少个扩展名为“.conf”的文件,可以先通过“find /etc -name "*.conf"”命令找出符合条件的文件位置,由于 find 命令的输出结果也是每行一个文件记录,因此只需结合管道符号执行“wc -l”操作即可得出符合条件的文件数量

grep命令
在文件中查找并显示包含指定字符串的行
可以直接指定关键字符串作为查找条件,也可以使用复杂的条件表达式(例如,“^word”表示以 word 开头,“word$”表示以 word 结尾,“^$”表示空行)
格式
grep [选项] 查找条件 目标文件
常用命令选项
-i:查找时忽略大小写
-v: 反转查找,输出与查找条件不相符的行

在维护 Linux 操作系统的过程中,经常会遇到包含大量内容的配置文件,而其中往往包含了许多空行和以“#”开头的注释文字,当只需要分析其中的有效配置信息时,这些空行和注释文字的存在不利于快速浏览。使用 grep 命令可以过滤掉这些无关信息。例如,以下操作可以显示/etc/yum.conf 文件中以“#”开头的行和空行以外的内容。
grep -v "^#" /etc/yum.conf | grep -v "^$"

^是一个特殊字符,表示一行的开始(开头,就是说只用开头的才算)
为什么在这两个grep表达式中都要加^呢?
^#,如果不加^,那么任何包含#的行都会被匹配,而不仅仅是注释行(即那些以#开头的行)。^$,这个表达式用于匹配空行。空行就是那些没有任何字符(包括空格、制表符等)的行。^表示一行的开始,$表示一行的结束,所以^$就匹配那些开始和结束都在同一位置的行,即空行。gzip格式的文件通常具有.gz的后缀,gzip通常可以将纯文本内容压缩到原大小的40%左右。
bzip2通常可以将文件压缩到原始大小的10%至15%。虽然其压缩速度相对较慢,但解压速度较快,且压缩率通常高于gzip。
1-9代表级,别默认是6级别,
使用1级别压缩比例最少但是压缩速度最快 ,9级压缩比例最大但是压缩速度最慢。
xz 是一种高效的压缩工具,它使用LZMA(Lempel-Ziv-Markov chain-Algorithm)算法进行压缩。这种算法通常比传统的gzip压缩算法具有更高的压缩率,但压缩和解压缩速度可能较慢。
用法
xz [要压缩的文件]
zip -r [归档文件名.zip] [要压缩的文件或目录]
.zip文件。这使得zip在需要处理多个文件或目录的压缩场景中更加灵活(但是压缩率不如bzip2)。以下是xz、bzip2、zip和gzip的简要区分表格:
| 特性 | xz | bzip2 | zip | gzip |
|---|---|---|---|---|
| 压缩率 | 高 | 较高 | 中等 | 中等偏低 |
| 压缩速度 | 中等 | 较慢 | 较快 | 较快 |
| 解压速度 | 较快 | 较快 | 较快 | 较快 |
| 算法 | LZMA/LZMA2 | Burrows-Wheeler变换 + Huffman编码 | DEFLATE/LZ77等 | DEFLATE |
| 多文件支持 | 不支持 | 不支持 | 支持 | 不支持 |
| 归档功能 | 需要配合tar等工具 | 需要配合tar等工具 | 内置归档功能 | 需要配合tar等工具 |
| 错误修复能力 | 无特别说明 | 有一定能力 | 无特别说明 | 无特别说明 |
| 跨平台性 | 是 | 是 | 是 | 是 |
| 扩展名 | .xz | .bz2 | .zip | .gz |
| 典型应用场景 | 需要高压缩率,如软件分发 | 需要高压缩率,如软件分发、备份 | 归档多个文件,如文档、图片等 | 压缩单个文件,尤其是文本文件 |
请注意,这个表格是基于一般情况下的观察和比较,具体表现可能会因文件类型、文件大小、硬件性能等因素而有所不同。在选择压缩工具时,最好根据具体需求进行测试和评估。
打一个文件


压缩后大小,bizp2小一些,说明压缩率高一些

扩展
time command 时,shell会先运行 command,然后在命令完成后显示其执行时间。-c 选项告诉gzip将输出(即压缩后的数据)直接发送到标准输出(stdout),而不是写入文件。> 符号将前面命令的标准输出(stdout)重定向到一个文件。结合-c,gzip -c ceshisize.txt 的输出(即ceshisize.txt 的压缩版本)被重定向到名为 1.txt的文件中。归档文件通常是一个或多个文件和目录的集合,它们被打包成一个单独的文件以便于存储、传输或备份。tar 命令本身不提供压缩功能,但可以与压缩工具(如 gzip、bzip2、xz 等)结合使用以创建压缩归档文件。
补充:
在 Linux 操作系统中,最简单的文件和目录备份工具就是 cp(复制)命令。但是当需要备份的文件、目录数量较多时,仅仅使用 cp 命令就显得“力不从心”,并且备份的文件数量及其所占用的磁盘空间都可能会对服务器产生不小的压力。因此,有必要对需要备份的数 据进行归档和压缩。
这里所说的归档操作实际上相当于“打包”,即将许多个文件和目录合并保存为一个整体 的包文件,以方便传递或携带。而压缩操作可以进一步降低打包后的归档文件所占用的磁盘 空间,充分提高备份介质的利用率。
tar 【选项】 归档文件名 源文件或目录
tar [选项】归档文件名 【c目标目录】
tar 命令主要用于对目录和文件进行归档。在实际的备份工作中,通常在归档的同时也会将包文件进行压缩(需要调用前面的 gzip 或 bzip2 命令),以节省磁盘空间。使用 tar 命令时,选项前的“-”号可以省略。常用的几个选项如下所述。
常用的组合命令
czvf xzvf
cjvf xjvf
czf xzf
cjf xjf
假设我们要创建一个 /etc 和 /opt/文件夹的归档文件,并且还希望使用 gzip 工具将其压缩。可以使用 tar 命令中的 -z 选项来实现。此类归档文件的扩展名是 tar.gz 或 tgz
需要注意的是,在备份恢复目录或文件时,最好先将工作路径切换至目标目录或文件的所在路径,然后在执行备份命令时使用相对路径,以防输入命令时因手误而导致根目录“/” 下重要文件损坏。
czvfp

当然我们还可以排除
- --exclude=*.conf
- 那么tar -jcpvf archive.tar.bz2 /etc/ /opt/ --exclude=*.conf
tvf

-x:解开.tar 格式的包文件。
-C:解压时指定释放的目标文件夹。
tar -xjvf b.tar.gz -C /kgc
在大部分的备份及恢复工作中,只使用 tar 命令就可以很好地结合 gzip、bzip2 工具协同工作,无须再执行 gzip 或 bzip2 命令。但是要注意这两个压缩工具的命令程序必须存在。