文章目录
计算机系统
5G云计算
第二章 LINUX目录和文件管理
一、Linux目录结构
1)树形目录结构
2)根目录
①所有分区、目录、文件等的位置起点
②整个树形目录结构中,使用独立的一个“/”表示
2)常见的子目录
/root /bin /boot /dev /etc
/home /var /usr /sbin
目录 | 说明 |
---|---|
/root | 管理员的宿主(家)目录 |
/home/xxx | 除 root 用户之外的普通用户的家目录,/home为除 root 用户之外的普通用户的家目录的父目录 |
/bin | 存放二进制文件,所有用户可执行的命令。实际是个软链接,链接到/usr/bin |
/sbin | 存放二进制文件,只有管理员可执行的管理命令。软链接到/usr/sbin |
/boot | 系统内核、启动文件目录 |
/dev | 存放设备文件(光驱、硬盘等) |
/etc | 存放系统程序和大部分应用程序(rpm、yum安装)的配置文件 |
/var | 存放可以变化的文件,包括各种日志文件 |
/lib | 存放系统程序的动态连接共享库文件(类似于Windows里的DLL文件)。软链接到/usr/lib |
/usr | 存放系统用户工具和程序 |
/media | 可拆卸的媒介挂载点,例如U盘、光驱等 |
/mnt | 用于临时挂载储存设备的目录 |
/opt | 第三方应用程序安装所存放的目录 |
/tmp | 存放系统的临时文件,/tmp 目录下的临时文件会被系统定期删除或者关机时自动删除 |
/proc | 存放映射系统信息的文件,是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关系统硬件及当前正在运行进程的信息,甚至可以通过更改其中某些文件来改变内核的运行状态 |
二、查看及检索文件
1.查看文件内容
cat <选项> <参数(文件名)>
选项 | 说明 |
---|---|
-n | 对所有输出的行数编号 |
-b | 对于空白行不编号 |
-s | 将所有的连续的多个空行替换为一个空行 |
more <选项> <参数(文件名)>
全屏方式分页显示文件内容
操作方法
1)按Enter键向下逐行滚动
2)按空格键向下翻一屏
3)按b键向上翻一屏
4)按q键退出
下翻到最后一页会自动退出
结合管道符操作使用时,无法向上翻页
less <选项> <参数(文件名)>
与more命令相同,但扩展功能更多
操作方法
1)Page Up向上翻页,Page Down向下翻页
2)按“/”键查找内容,“n”下一个内容,“N”上一个内容
3)通过↑和↓方向键可以实现上下逐行滚动
4)其他功能与more命令基本类似
下翻到最后一页后不会自动退出
结合管道操作使用时可以向上翻页
head <-n> <参数(文件名)> ###n为行数,查看文件开头的一部分内容(默认为10行)
head <-n> <+k> <参数(文件名)> ###等于head -n
head <-n> <-k> <参数(文件名)> ###显示除了最后k行的其他内容
tail <-n> <参数(文件名)> ###n为行数,查看文件结尾的少部分内容(默认为10行)
tail <-n> <-k> <参数(文件名)> ###等于tail -n
tail <-n> <+k> <参数(文件名)> ###从第k行显示到最后
tail <-f> <参数(文件名)> ###跟踪文件尾部内容的动态更新
通过head和tail及其两个命令的+/-k的高级应用方法,可以选取中间某几行显示
例:选取10-15行
第一种
第二种
第三种
2.统计文件内容
wc <选项> <参数(文件名)>
选项 | 说明 |
---|---|
-l | 统计行数 |
-w | 统计单词个数 |
-c | 统计字节数 |
不带任何选项的wc命令,默认同时使用-lwc三个选项
通过与cat的组合命令可以去掉结果显示中的文件名
3.检索和过滤文件内容
查找条件设置(正则表达式)
“^XXX”表示以XXX开头
“XXX$”表示以XXX结尾
“^$”表示空行
grep <选项> <查找条件> <参数(文件名)>
选项 | 说明 |
---|---|
-i | 查找时不区分大小写 |
-v | 显示不包含匹配文本的所有行(反向查询,反向匹配) |
-c | 只输出匹配到的总行数(不是匹配到的次数) |
-n | 显示匹配行及行号 |
-e | 实现可多个查找条件的匹配,逻辑or关系 |
-E | 支持使用扩展正则表达式,相当于使用egrep命令 |
-o | 精确匹配,即“仅匹配”之意 |
-A | 显示匹配行和它后面的n行 |
-B | 显示匹配行和它前面的n行 |
-C | 匹配行和它前后各n行 |
-l | 列出文件内容符合指定的样式的文件名称 |
-w | 只显示全字符合的行 |
-R(-r) | 递归的检索当前目录下所有子目录和文件 |
三、压缩及解压缩文件
gzip <-9> <源文件或目录(要压缩的文件或目录)>
gzip <-d> <文件名.gz(要解压缩的压缩包)>
gunzip <文件名.gz(要解压缩的压缩包)>
bzip2 <-9> <源文件或目录(要压缩的文件或目录)>
bzip2 <-d> <文件名.bz2(要解压缩的压缩包)>
bunzip2 <文件名.bz2(要解压缩的压缩包)>
gzip 制作的压缩文件默认的扩展名为“.gz”,原始文件不保留,解压后压缩包也不保留
bzip2 制作的压缩文件默认的扩展名为“.bz2”,原始文件不保留,解压后压缩包也不保留
使用“-9”选项可以提高压缩的比率
指令的值可为1(压缩速度最快,最低的压缩质量)至9(最慢的压缩速度,压缩率最高)之间的整数,其默认值为6(压缩速度和压缩质量较为平衡的值)
tar <选项> <归档文件名(创建的压缩包的名字)> <源文件或目录(要压缩的文件或目录)>
tar <选项> <归档文件名(要解压缩的压缩包的名字)> [-C 目标目录(解压缩到指定目录)]
选项 | 说明 |
---|---|
-c(小写) | 创建.tar 格式的包文件 |
-x | 解开.tar 格式的包文件 |
-C(大写) | 解压时指定释放的目标文件夹 |
-f | 表示使用归档文件(必带选项) |
-p(小写) | 打包时保留文件及目录的权限 |
-P(大写) | 打包时保留文件及目录的绝对路径 |
-t | 列表查看包内的文件 |
-v | 输出详细信息(Verbose) |
-j | 调用 bzip2 程序进行压缩或解压 |
-z | 调用 gzip 程序进行压缩或解压 |
zip <文件名.zip(创建的压缩包的名字)> <源文件或目录(要压缩的文件或目录)>
unzip <文件名.zip(要解压缩的压缩包的名字)> [-d 目标目录(解压缩到指定目录)]
四、vi文本编辑器
1.文本编辑器的作用
1)创建或修改文本文件
2)维护Linux系统中的各种配置文件
2.Linux中最常用的文本编辑器
1)vi:类UNIX操作系统的默认文本编辑器
2)vim:vim是vi文本编辑器(一般简称vi编辑器)的增强版本
3.三种工作模式
命令模式:启动vi编辑器后默认进入命令模式,该模式中主要完成光标移动、字符串查找,以及删除、复制、粘贴文件内容等相关操作
输入模式(编辑模式):该模式中主要的操作就是录入文件内容,可以对文本文件正文进行修改、或者添加新的内容。处于输入模式时,vi编辑器的最后一行会出现“–INSERT(插入)–”的状态提示信息
末行模式(尾行模式):该模式中可以设置vi编辑器环境、保存文件、退出编辑器,以及对文件内容进行查找、替换等操作。处于末行模式时,vi编辑器的最后一行会出现冒号“:”提示符
vi <文件名>
vim <文件名>
!vim ###返回上一次编辑的文件
命令模式命令 | 说明 |
---|---|
a | 在当前光标位置之后插入内容 |
i | 在当前光标位置之前插入内容 |
o(小写) | 在光标所在行之下插入一个新行内容 |
O(大写) | 在光标所在行之上插入一个新行内容 |
A | 在所在行的行尾插入内容 |
I | 在所在行的行首插入内容 |
命令模式操作类型 | 操作键 | 功能 |
---|---|---|
翻页移动 | Page Down键或 Ctrl+F Page Up键或 Ctrl+B | 向下翻动一整页内容 向上翻动一整页内容 |
行内快速跳转 | Home键或^键、数字 0键 End 键或$键 | 跳转到本行的行首 跳转到本行的行尾 |
行间快速跳转 | 1G 或 gg G #G M | 转到文件内容的第 1 行 跳转到文件的最后一行 跳转到文件中的第#行(其中“#”号用具体数字替换) 跳转至当前页的中间位置 |
删除 | x或Delete键 dd #dd d^ d$ dw | 删除光标处的单个字符 删除当前光标所在行(有剪切功能) 删除从光标处开始的#行内容<br/>删除当前光标之前到行首的所有字符 删除当前光标处到行尾的所有字符 删除光标处的整个单词 |
替换字符 | R 或 Shift+r | 替换当前光标处字符 |
复制 | yy #yy | 复制当前行整行的内容到剪贴板 复制从光标处开始的#行内容 |
粘贴 | p P | 粘贴到光标所在行之下 粘贴到光标所在行之上 |
撤销 | u U Ctrl+R | 按一次取消最近的一次操作;重复u键,恢复多步操作 用于取消最后一次操作所在行所做的所有编辑 恢复撤销的操作 |
末行模式操作类型 | 操作键 | 功能 |
---|---|---|
显示行号 | :set nu :set nonu | 在编辑器中显示行号 取消行号显示 |
查找 | /word ?word n N | 从当前光标处开始向后进行查找字符串“word” 从当前光标处开始向前进行查找 定位下一个匹配的被查找字符串 定位上一个匹配的被查找字符串 |
保存退出 | :w :w 新文件名 :q :q! ZZ或:wq、:wq!、:x | 保存修改的内容 另存为其它文件 放弃对文件内容的修改并退出 保存当前的文件内容并退出vi编辑器 |
打开新文件 | :e 其它文件名 | 打开新的文件进行编辑 |
读入文件内容 | :r 其它文件名 | 在当前文件中读入其他文件内容 |
文件内容替换 | <:s /old/new> <:s /old/new/g> :#,# s/old/new/g :% s/old/new/g <:s /old/new/c> :8,11 m 4 :8,11 co 4 | 将当前行中查找到的第一个字符串“old” 串替换为“new” 将当前行中查找到的所有字符串“old” 替换为“new” 在行号“#,#”范围内替换所有的字符串“old”为“new” 在整个文件范围内替换所有的字符串“old”为“new” 在替换命令末尾加入c命令,将对每个替换动作提示用户进行确认 将8-11行的内容剪切到第4行下面 将8-11行的内容复制到第4行下面 |
小技巧 | SHIFT + 3 | 可在脚本文件中高亮所有的相关字符串 |