Typecho合集站

一个喜欢Typecho站长搭建的站点,为能服务更多typecho用户

Linux 文件管理基础


[/ul]


一、Linux文件命名规则

1)可以使用那些字符?

理论上除了字符“/”之外,所有的字符都可以使用,但是要注意,在目录名或文件名中,不建议使用某些特殊字符,例如, <、>、?、* 等,尽量避免使用。

工作时文件的命名规则:

① 由于linux严格区分大小写,所以尽量都用小写字母

② 如果必须对文件名进行分割,建议使用"_",例如:ops_2021_2.log

_ 下划线,在Linux操作系统中,可以使用Shift键 + 减号

2)文件名的长度

目录名或文件名的长度不能超过 255 个字符

尽量不要太长,另外文件名称一定要见名知意,可以使用英文单词

3)文件名的大小写

Linux目录名或文件名是区分大小写的。如Ops、ops、yunwei 和 YUNWEI,是互不相同的目录名或文件名。

建议:

不要使用字符大小写来区分不同的文件或目录。
建议文件名一律使用小写字母

4)Linux文件拓展名

Linux文件的扩展名对 Linux 操作系统没有特殊的含义,Linux 系统并不以文件的扩展名开分区文件类型。例如,shell.exe 只是一个文件,其扩展名 .exe 并不代表此文件就一定是可执行的。

在Linux系统中,文件扩展名的用途为了使运维人员更好的区分不同的文件类型。

在Linux操作系统中,文件的类型是依靠权限位的标识符来进行区分的。当然也可以通过颜色,如白色普通文件,天蓝色文件夹

二、Linux文件管理基础

1)目录的创建

在实际应用中,与目录相关的操作主要有两个:创建目录与删除目录

① mkdir创建目录

基本语法:

# mkdir 目录名称

主要功能:就是根据目录的名称创建一个目录

mkdir = make directory

案例:在家目录下创建一个script的文件夹

# mkdir script

② mkdir -p递归创建目录

基本语法:

# mkdir -p /usr/local/nginx/conf选项说明:-p:递归创建,从左边的路径开始一级一级创建目录,直到路径结束

案例:在已知目录(/usr/local)下创建多级目录(nginx/conf)

# mkdir /usr/local/nginx/confmkdir: cannot create directory ‘/usr/local/nginx/conf’: No such file or directory
mkdir:不能创建目录conf,为什么呢?因为/usr/local目录下并没有nginx

解决方案:如果我们想同时创建多级目录,必须使用-p选项,其会从左向右一级一级创建目录。

# mkdir -p /usr/local/nginx/conf

③ 使用mkdir同时创建多个目录

# mkdir 目录名称1 目录名称2 目录名称3 ...

案例:在当前目录下创建a、b、c三个目录

# mkdir a# mkdir b# mkdir c或# mkdir a b c

总结:

一个目录一个目录创建# mkdir 目录名称

多级目录一起创建# mkdir -p 目录名称1/目录名称2/...

同时创建多个目录# mkdir 目录名称1 目录名称2 目录名称3

扩展:Linux快捷键(方向键上下)

在终端中:

按方向键=>向上,其会返回上一次输入的命令

按方向键=>向下,其会返回下一次输入的命令

2)目录删除(必须是空目录)

① rmdir移除空目录

基本语法:

# rmdir 目录名称

rmdir = remove directory,移除目录

案例:把家目录下的script删除(空目录)

# rmdir script

② rmdir -p递归删除空目录

基本语法:

# rmdir -p 目录名称1/目录名称2/目录名称3/...

主要功能:从右向左一级一级删除空目录

案例:递归删除script文件夹中的yunwei文件夹中的ops

# rmdir -p script/yunwei/ops

③ 使用rmdir同时删除多个空目录

# rmdir 目录名称1 目录名称2 目录名称3 ...

案例:删除家目录中的a、b、c三个空目录

# rmdir a b c

总结:

# rmdir 目录名称,删除某个空目录

# rmdir -p 目录名称1/目录名称2/目录名称3/...,同时删除多级目录(从右向左一级一级删除)

# rmdir 目录名称1 目录名称2 目录名称3,同时删除多个空目录

3)文件创建

① touch创建文件

基本语法:

# touch 文件名称

主要功能:在Linux系统中的当前目录下创建一个文件

案例:在当前目录下创建一个readme.txt文件

# touch readme.txt

② 使用touch命令同时创建多个文件

基本语法:

# touch 文件名称1 文件名称2 文件名称3 ...

案例:创建一个shop商城文件夹,然后在内部创建index.php/admin.php/config.php三个文件

# mkdir shop# touch shop/index.php# touch shop/admin.php# touch shop/config.php或# touch shop/index.php shop/admin.php shop/config.php

提出问题:观察以下命令,看看有何区别?

第一种写法:touch shop/index.php shop/admin.php shop/config.php

代表在shop目录下首先创建一个index.php,在创建一个admin.php,最后config.php

第二种写法:touch shop/index.php admin.php config.php

代表在shop目录下首先创建index.php,然后在当前目录下创建admin.php,最后在当前目录下创建config.php

③ {1…5}根据序号同时创建多个文件

基本语法:

# touch 文件名称{开始序号..结束序号}含义:
根据提供的开始序号~结束序号,一个一个创建文件

案例:创建file1、file2、file3、file4、file5共5个文件

# touch file1# touch file2# touch file3# touch file4# touch file5

# touch file{1..5}

总结:

# touch 文件名称

# touch 文件名称1 文件名称2 文件名称3 ...

# touch文件名称{开始序号..结束序号}

4)文件删除

① 普通删除

基本语法:

# rm  [选项]  文件或文件夹的名称选项说明:-r :针对文件夹,代表递归删除,先把目录下的所有文件删除,然后在删除文件夹-f :强制删除,不提示,一定要慎重!!!

案例:删除readme.txt文件

# rm readme.txtrm: remove regular empty file ‘readme.txt’?这里可以回复y or n
y代表确认删除
n代表取消删除

案例:强制删除admin.php,不提示(慎重)

# rm -f admin.php

案例:删除非空的文件夹(-rf强制递归删除,不提示)

# rm -rf shop

提示信息:descend into directory ‘script/’?
含义:是否进入script目录?

提示信息:remvoe directory ‘script/’?
含义:是否删除script文件夹?

扩展:Ctrl + C在Linux下的使用方式

在Linux操作系统中,Ctrl + C不是复制,而是中断某个操作

总结:

# rm 文件名称

# rm 文件名称1 文件名称2 文件名称3 ...

# rm -f 文件名称 => 强制删除,不提示

# rm -rf 文件夹名称 => 递归删除文件夹

② 扩展:rm -rf /*,一定要慎重

# rm -rf /*	    =>   代表删除根目录下的所有文件(如果没有备份,恢复的几率不高)rm :删除-r :递归删除(无论文件夹是否为空)-f :强制删除不提示/  :代表根分区*  :所有

5)复制操作

① cp复制操作

基本语法:

# cp [选项] 源文件或文件夹 目标路径选项说明:-r :递归复制,主要针对文件夹

cp = copy复制

案例:把readme.txt文件从当前目录复制一份放到/tmp文件夹中

# cp readme.txt /tmp/

② cp复制并重命名文件

基本语法:

# cp [选项] 源文件或文件夹 目标路径/新文件或文件夹的名称

案例:把readme.txt文件从当前目录复制一份放到/tmp文件夹中并重命名为readme.txt.bak

# cp readme.txt /tmp/readme.txt.bak

③ cp复制文件夹到指定路径

# cp -r 源文件夹名称 目标路径/

案例:把shop目录连通其内部的文件统一复制到/tmp目录下

# mkdir shop# touch shop/index.php shop/admin.php shop/config.php# cp -r shop /tmp/

总结:

复制文件# cp 源文件名称 指定路径

复制文件并重命名# cp 源文件名称 指定路径/新文件名称

复制文件夹# cp -r 源文件夹 指定路径

6)剪切操作

基本语法:

# mv 源文件或文件夹 目标路径/

mv = move,剪切、移动的含义

案例:把readme.txt文件剪切到/tmp目录下

# rm -rf /tmp/readme.txt# mv readme.txt /tmp/

案例:把shop文件夹移动到/usr/local/nginx目录下

# mkdir /usr/local/nginx# mv shop /usr/local/nginx/

7)重命名操作

什么是重命名?简单来说,就是给一个文件或文件夹更改名称

基本语法:

# mv  源文件或文件夹名称  新文件或文件夹的名称

案例:把readme.txt文件更名为README.md文件

# mv readme.txt README.md

案例:把shop文件目录更名为wechat目录

# mkdir shop# mv shop wechat

总结:

剪切文件# mv 源文件名称 目标路径/

剪切文件夹# mv 源文件夹名称 目标路径/

重命名# mv 源文件或文件夹名称 新文件或文件夹名称

8)打包压缩与解压缩

① 几个概念

打包:默认情况下,Linux的压缩概念一次只能压缩一个文件。针对多文件或文件夹无法进行直接压缩。所以需要提前对多个文件或文件夹进行打包,这样才可以进行压缩操作。

1.txt 5MB

2.txt 10MB

3.txt 15MB

1.txt + 2.txt + 3.txt = 打包 = 123.tar = 30MB

打包只是把多个文件或文件夹打包放在一个文件中,但是并没有进行压缩,所以其大小还是原来所有文件的总和。

压缩:也是一个文件和目录的集合,且这个集合也被存储在一个文件中,但它们的不同之处在于,压缩文件所占用的磁盘空间比集合中所有文件大小的总和要小。

1.txt 5MB

2.txt 10MB

3.txt 15MB

1.txt + 2.txt + 3.txt = 压缩 = 123.tar.gz = 20MB(体积变小了)

② Linux打包操作

基本语法:

# tar [选项]  打包后的名称.tar  多个文件或文件夹选项说明:-c :打包-f :filename,打包后的文件名称-v :显示打包的进度-u :update缩写,更新原打包文件中的文件(了解)-t :查看打包的文件内容(了解)

案例:把a.txt、b.txt、c.txt文件打包到abc.tar文件中

# tar -cvf abc.tar a.txt b.txt c.txt

案例:把wechat文件夹进行打包wechat.tar

# tar -cvf wechat.tar wechat

③ tar -tf以及tar -uf

# tar -tf 打包后的文件名称

主要功能:查看tar包中的文件信息

案例:查看abc.tar包中的文件信息

# tar -tf abc.tar

# tar -uf 打包后的文件名称

u = update,更新,如果还想往tar包中更新或追加内容都可以通过-u选项

案例:向abc.tar包中添加一个d.txt文件

# touch d.txt# tar -uf abc.tar d.txt查看是否添加成功# tar -tf abc.tar

扩展:如何把tar包中的文件释放出来

打包# tar -cf  abc.tar  a.txt  b.txt  c.txt打包 => 释放(-c 变成 -x)

释放# tar -xf  abc.tar

④ 打包并压缩(!)

基本语法:

# tar [选项]  压缩后的压缩包名称  要压缩的文件或文件夹选项说明:-cf :对文件或文件夹进行打包-v  :显示压缩进度-z	:使用gzip压缩工具把打包后的文件压缩为.gz-j  :使用bzip2压缩工具把打包后的文件压缩为.bz2-J	:使用xz压缩工具把打包后的文件压缩为.xz

压缩速度:gzip > bzip2 > xz
压缩率:gzip < bzip2 < xz
100M   90M     80M	  70M

案例:把a.txt、b.txt、c.txt文件打包并压缩为abc.tar.gz

# tar -zcf abc.tar.gz a.txt b.txt c.txt

案例:把wechat文件夹压缩为wechat.tar.gz格式的压缩包

# tar -zcf wechat.tar.gz wechat

⑤ 对压缩包进行解压

解压过程非常简单,就是把压缩的参数中的c换成x就可以实现解压缩了

*.tar.gz格式的压缩包# tar -zxf 名称.tar.gz*.tar.bz2格式的压缩包# tar -jxf 名称.tar.bz2*.tar.xz格式的压缩包# tar -Jxf 名称.tar.xz

案例:把abc.tar.gz格式的压缩包进行解压缩操作

# tar -zxf abc.tar.gz

案例:把wechat.tar.gz格式的压缩包进行解压缩操作

# tar -zxf wechat.tar.gz

9)zip压缩与解压缩

① zip压缩

基本语法:

# zip [选项] 压缩后的文件名称.zip  文件或文件夹选项说明:-r :递归压缩,主要
8000
针对的是文件夹

Linux下已经有gzip、bzip2以及xz压缩命令了,为什么还需要使用zip压缩呢?

答:zip格式在Windows以及Linux中都是可以正常使用的。

案例:把a.txt、b.txt、c.txt进行压缩为abc.zip

# zip abc.zip a.txt b.txt c.txt

案例:把wechat文件夹压缩为wechat.zip

# zip -r wechat.zip wechat

② unzip解压缩

基本语法:

# unzip 压缩包名称		=>     解压到当前目录# unzip 压缩包名称 -d 指定路径		=>   解压到指定路径下

案例:对abc.zip文件进行解压缩

# unzip abc.zip

案例:把wechat.zip解压到/usr/local/nginx目录下

# unzip wechat.zip -d /usr/local/nginx/

总结:

在Linux操作系统中,其拥有很多压缩工具,如gzip、bzip2、xz等等,但是其有一个缺点:

一次只能压缩一个文件(而且无法压缩文件夹)

① 打包,把一个或多个文件打成tar包,并不是压缩,只是把文件合并在一个tar文件中

1.txt 5MB

2.txt 10MB

3.txt 15MB

打包123.tar = 5MB + 10MB + 15MB = 30MB

为什么要打包,就是为了后期的压缩操作。

② 打包并压缩

# tar -zcf 压缩包名称.tar.gz 文件或文件夹名称# tar -jcf 压缩包名称.tar.bz2 文件或文件夹名称# tar -Jcf 压缩包名称.tar.xz 文件或文件夹名称

③ 解压缩

# tar 把c参数更换为x,就可以实现解压缩  压缩包名称.tar.gz

扩展:

# tar -zxf 压缩包名称.tar.gz [参数] 指定路径

不熟那该啷个儿搞噢?

一:随用随查,百度、Google

# tar -zxf 压缩包名称.tar.gz -C 指定路径

二:可以使用man命令(manual缩写,手册)

# man tar命令# tar -zxf 压缩包名称.tar.gz -C 指定路径

④ zip压缩与解压缩

给我们提供一种既可以在Windows中使用的,也可以提供一种在Linux中使用的通用的压缩格式。

# zip [-r]  压缩包名称.zip  要压缩的文件或文件夹

解压缩:

# unzip 压缩包名称.zip  -d 指定路径

三、文本处理命令

1)查看文本内容

①cat查看及合并

[root@hsforpyp demo]# cat 1.txt 
123456
用法一:显示1.txt文件的内容
特别注意:cat 命令用于查看文件内容时,不论文件内容有多少,都会一次性显示。如果文件非常大,那么文件开头的内容就看不到了。cat 命令适合查看不太大的文件。

[root@hsforpyp demo]# cat 1.txt 2.txt > 3.txt
[root@hsforpyp demo]# cat 3.txt 
123456
qwerdf
用法二:将1.txt和2.txt文件内容合并后,输出到3.txt

②tac倒序输出文件

主要功能:倒序输出文件的内容

[root@hsforpyp demo]# cat 1.txt 123
456[root@hsforpyp demo]# tac 1.txt 456
123

③more分屏显示文件

流程:more在读取文件时,默认已经加载文件的全部内容。

格式:more 文件名
示例代码:
[root@hsforpyp demo]# more /var/log/boot.log
含义:分页显示/var/log/boot.log文件的内容

more 命令的执行会打开一个交互界面,下面是一些常用交互命令:

回车键向下移动一行。
d向下移动半页。
空格键向下移动一页。
b向上移动一页。
/ 字符串搜索指定的字符串。
:f显示当前文件的文件名和行号。
q 或 Q退出 more。

④less分屏显示文件

流程:不是加载整个文件,而是一点一点进行加载,相对而言,读取大文件时,效率比较高。

示例代码:使用less命令查看/var/log/boot.log的文件内容

用法一:less 文件名
示例代码:[root@hsforpyp demo]# less /var/log/boot.log含义:分页显示/var/log/boot.log文件的内容

less 命令的执行也会打开一个交互界面,下面是一些常用交互命令(和more相同):

回车键向下移动一行。
d向下移动半页。
空格键向下移动一页。
b向上移动一页。
/ 字符串搜索指定的字符串。
:f显示当前文件的文件名和行号。
q 或 Q退出 less。

cat,more,less三者的对比:


catmoreless
作用显示小文件(一屏以内)显示大文件(超过一屏)显示大文件(超过一屏)
交互命令
上下键翻行

⑤head显示文件开头

用法一:head 文件名
示例代码:#head /var/log/boot.log含义:显示/var/log/boot.log文件的内容,默认为前10行

用法二:head -n 文件名
示例代码:#head -3 /var/log/boot.log含义:显示/var/log/boot.log文件的前3行内容

⑥tail显示文件结尾(!)

用法一:tail 文件名
示例代码:#tail /var/log/boot.log含义:显示/var/log/boot.log文件的内容,默认为最后10行

用法二:tail -n 文件名
示例代码:#tail -5 /var/log/boot.log含义:显示/var/log/boot.log文件的最后5行内容

用法三:tail -f 文件名
示例代码:#tail -f /var/log/messages含义:显示/var/log/messages文件中,执行tail -f 命令后,新增的数据。
注意:作用相当于查看一个文件动态变化的内容,一般用于查看系统的日志的变化
     按下ctrl+c可以退出查看状态

2)统计文件信息

①wc统计文件内容数量

wc = word count
作用:用于统计文件内容信息(包含行数、单词数、字节数)
常见参数:

-l:表示lines,行数(以回车/换行符为标准)

-w:表示words,单词数 依照空格来判断单词数量

-c:表示bytes, 字节数(空格,回车,换行)

用法一:wc -lwc 文件名
示例代码:[root@hsforpyp demo]# wc -lwc /var/log/boot.log
  174  1278 10144 /var/log/boot.log
含义:统计/var/log/boot.log文件的行数,单词数,字节数
注意:wc命令选项可以混在一起搭配使用,但选项的顺序不影响输出结果,第一个是行数,第二个是单词数,第三个数字节数。

②du统计文件大小

作用:查看文件或目录(会递归显示子目录)占用磁盘空间大小
常见参数:-s :summaries,只显示汇总的大小,统计文件夹的大小

-h:表示以高可读性的形式进行显示,如果不写-h,默认以KB的形式显示文件大小

用法一:du 文件名
示例代码:#du /var/log/boot.log含义:统计/var/log/boot.log文件的大小

用法二:du -h 文件名
示例代码:#du -h /var/log/boot.log含义:统计/var/log/boot.log文件的大小,以高可读性显示

用法三:du 目录名
示例代码:#du /var/log/含义:统计/var/log/目录的大小,包含目录下每一个单独文件的大小

用法四:du -s 目录名
示例代码:#du -s /var/log/含义:统计/var/log/boot.log文件的大小,汇总只显示目录大小

用法五:du -sh 目录名
示例代码:#du -sh /var/log/含义:统计/var/log/boot.log文件的大小,汇总只显示目录大小,并采用高可读性

3)文本处理

①find文件查找(!)

作用:用于查找文档(其选项有55 个之多)

语法:# find 路径范围 选项1 选项1的值 [选项2 选项2 的值…]

常用参数:

-name:按照文档名称进行搜索(支持模糊搜索)

* : 通配符,匹配任意个任意字符

-type:按照文档的类型进行搜索,文档类型的值,f(file)表示文件,d(directory)表示文件夹

用法一:find 路径范围 选项1 选项1的值 选项2 选项2的值
示例代码:
#find /var/ -name boot.log -type f
含义:在/var/目录下,查找名称等于boot.log,类型是文件的文档

用法二:find 路径范围 选项1 选项1的值使用通配符 选项2 选项2的值
示例代码:
#find /var/log -name "*.log" -type f
含义:在/var/log目录下,查找所有.log结尾,类型是文件的文档,*.log需要用引号引起来。

用法三:find 路径范围 选项1 选项1的值
示例代码:
#find /var/log -type d
含义:在/var/log目录下,查找所有文件夹

②grep搜索文件内容 (!)

作用:在文件中直接找到包含指定信息的那些行,并把这些信息显示出来

语法:#grep 要查找的内容 文件名

用法一:grep 查找的内容 文件名
示例代码:#grep network boot.log含义:在boot.log文件中,查找包含network的行

用法二:grep 查找的内容 多个文件
示例代码:#grep network /var/log/*含义:在/var/log目录下的所有文件中,查找包含network的行

③输出重定向

场景:一般命令的输出都会显示在终端中,有些时候需要将一些命令的执行结果想要保存到文件中进行后续的分析/统计,则这时候需要使用到的输出重定向技术。

>:标准输出重定向 :覆盖输出,会覆盖掉原先的文件内容

>>:追加重定向 :追加输出,不会覆盖原始文件内容,会在原始内容末尾继续添加

语法:#有输出的命令 重定向符号 文件名

用法一:使用 > 进行覆盖输出
示例代码:
[root@hsforpyp demo]# cat 1.txt 
123456
[root@hsforpyp demo]# echo "123">1.txt
[root@hsforpyp demo]# cat 1.txt 
123
含义:将echo命令输出的内容,写入到1.txt 文件中,如果1.txt 文件中有其他内容,则先清空,在写入
注意:文件路径中的文件可以是不存在的文件,例如1.txt 可以不存在,执行命令时会自动创建这个文件

用法二:使用 >> 进行追加输出
示例代码:
[root@hsforpyp demo]# echo "456">>1.txt
[root@hsforpyp demo]# cat 1.txt 
123
456
含义:将echo命令输出的内容,追加写入到1.txt文件中
注意:文件路径中的文件可以是不存在的文件,例如1.txt可以不存在,执行命令时会自动创建这个文件


上一篇 : Ubuntu20.04 安装 mysql8.0 之后 root 账户无法登录
下一篇 : Linux Vim编辑器的基本使用

发表新评论