Linux基础运维篇:Linux文件操作超详细版(第007课)
ahcoder 2025-05-10 19:23 13 浏览
一、Linux 文件系统基础
1. 文件类型
Linux 一切皆文件,常见文件类型:
- 普通文件(-):文本文件(.txt)、二进制文件(可执行程序)、压缩文件等。
- 目录文件(d):用于组织文件和子目录(类似 Windows 文件夹)。
- 链接文件(l):软链接(快捷方式)和硬链接(指向同一物理文件的不同名称)。
- 设备文件(b/c):/dev 目录下,b 表示块设备(如硬盘),c 表示字符设备(如串口)。
- 管道文件(p):用于进程间通信(IPC)的 FIFO 文件。
- 套接字文件(s):用于进程间网络通信(如 /var/run/sshd.sock)。
2. 文件系统结构(树形目录)
/ 根目录,所有文件的起点
├─ bin 存放用户可执行命令(如 ls、cp)
├─ sbin 存放管理员可执行命令(如 shutdown、reboot)
├─ etc 系统配置文件(重要!修改前建议备份)
├─ home 用户主目录(如 /home/user1)
├─ var 可变数据(日志、缓存、临时文件)
├─ dev 设备文件和特殊文件
├─ tmp 临时文件(通常重启后清空)
├─ usr 用户程序和数据(类似 Windows 的 Program Files)
└─ proc 虚拟文件系统(存储进程信息,如 /proc/self/exe)
二、基础文件操作命令(必学)
1. 查看文件 / 目录列表:ls
ls [-alhtr] 路径 # 常用选项:
-a 显示隐藏文件(以 . 开头的文件)
-l 长格式显示(权限、大小、时间等)
-h 人性化大小显示(KB/MB/GB)
-t 按修改时间排序
-r 反向排序
示例:
ls -l /etc/hosts # 查看文件详细信息
ls -alth ~ # 查看当前用户主目录,按时间倒序,显示隐藏文件
2. 切换目录:cd
cd 目录路径 # 切换目录
cd ~ # 回到用户主目录
cd - # 切换回上一次目录
cd .. # 进入上级目录
cd ../.. # 进入上上级目录
3. 创建文件 / 目录:touch/mkdir
touch 文件名 # 创建空文件(若文件存在则更新时间戳)
mkdir 目录名 # 创建目录
mkdir -p 多级目录 # 递归创建目录(如 mkdir -p a/b/c)
4. 删除文件 / 目录:rm
rm 文件名 # 删除文件(需确认,无回收站!)
rm -r 目录名 # 删除目录(递归删除)
rm -f 文件名 # 强制删除(忽略不存在或权限问题)
rm -rf 目录名 # 强制递归删除(危险!慎用!)
5. 复制文件 / 目录:cp
cp 源文件 目标路径 # 复制文件
cp -r 源目录 目标路径 # 复制目录(需加 -r)
cp -n 源文件 目标路径 # 不覆盖已存在文件
cp -v 源文件 目标路径 # 显示复制过程
6. 移动 / 重命名文件:mv
mv 旧文件名 新文件名 # 重命名文件
mv 源文件 目标目录 # 移动文件到目标目录
mv -n 源文件 目标路径 # 不覆盖已存在文件
三、文件内容操作
1. 查看文件内容
- 快速预览(适合小文件):
cat 文件名 # 显示文件全部内容(从第一行到最后一行)
nl 文件名 # 显示内容并带行号
- 分页查看(适合大文件):
more 文件名 # 分页显示,按空格翻页,按 q 退出
less 文件名 # 增强版 more,支持上下箭头滚动、搜索(输入 /关键词 查找)
- 查看首尾内容:
head 文件名 # 默认显示前 10 行(-n 行数 指定行数)
tail 文件名 # 默认显示最后 10 行(-n 行数 指定行数)
tail -f 文件名 # 实时监控文件更新(如日志文件)
2. 编辑文件
- 简单文本编辑器:
nano 文件名 # 适合新手,界面友好,快捷键提示在底部
- 高效编辑器(需学习):
vim 文件名 # 经典模式编辑器,分命令模式(按 Esc 进入)和插入模式(按 i 进入)
# vim 常用命令:
:w 保存
:q 退出
:wq 保存并退出
:set nu 显示行号
:/关键词 搜索
dd 删除当前行
四、文件权限管理(核心!)
1. 权限分类
- 所有者(User):文件的创建者或通过 chown 修改的用户。
- 所属组(Group):文件所属的用户组(可通过 chgrp 修改)。
- 其他用户(Others):非所有者、非所属组的用户。
2. 权限标识(ls -l输出的前 10 位)
d rwx r-x r--
1 234 567 89-
1:文件类型(d=目录,-=普通文件,l=链接)
2-4:所有者权限(r=读,w=写,x=执行)
5-7:所属组权限
8-10:其他用户权限
3. 权限操作命令
- 修改权限:
- chmod符号法(推荐,更直观):
chmod u+rwx,g+rw,o+r 文件名 # 给所有者添加 rwx,组添加 rw,其他用户添加 r
chmod u-x 文件名 # 移除所有者的执行权限
- 数字法(r=4,w=2,x=1,无 = 0):
chmod 755 文件名 # 所有者 rwx(7),组和其他用户 rx(5)
chmod 644 文件名 # 所有者 rw(6),组和其他用户 r(4)
- 修改所有者 / 所属组:chown / chgrp
chown 新用户 文件名 # 修改所有者
chown 新用户:新组 文件名 # 同时修改所有者和所属组
chgrp 新组 文件名 # 仅修改所属组
4. 特殊权限(进阶)
- SUID(Set UID):让普通用户执行文件时临时拥有所有者权限(如 chmod u+s 可执行文件)。
- SGID(Set GID):目录设置后,新建文件继承目录所属组(如 chmod g+s 目录)。
- 粘滞位(Sticky Bit):仅所有者可删除目录内文件(如 chmod o+t 目录)。
五、文件查找与过滤
1. 按文件名查找:find(强大但慢)
find 搜索路径 -name "文件名" # 精确匹配(支持通配符,如 *.log)
find /var -type f -size +100M # 在 /var 下找大于 100MB 的文件
find . -mtime -7 # 查找当前目录 7 天内修改的文件
find . -perm 644 # 查找权限为 644 的文件
2. 快速查找(基于数据库):locate
locate 文件名 # 需先执行 `updatedb` 更新数据库(通常自动运行)
3. 按内容搜索:grep
grep "关键词" 文件名 # 在文件中搜索关键词(区分大小写)
grep -i "关键词" 文件名 # 不区分大小写
grep -r "关键词" 目录 # 递归搜索目录下所有文件
grep -v "关键词" 文件名 # 排除包含关键词的行
六、高级文件操作技巧
1. 通配符(匹配文件名)
- *:匹配任意字符(0 个或多个),如 *.txt 匹配所有 txt 文件。
- ?:匹配单个任意字符,如 file?.txt 匹配 file1.txt、fileA.txt 等。
- [abc]:匹配括号内任意一个字符,如 [A-Z].txt 匹配以大写字母开头的 txt 文件。
- [!abc]:匹配不在括号内的字符,如 [!0-9].txt 匹配不以数字开头的 txt 文件。
2. 管道与重定向(结合多个命令)
- 重定向:
命令 > 文件名 # 将输出覆盖写入文件(原内容清空)
命令 >> 文件名 # 将输出追加写入文件(原内容保留)
命令 < 文件名 # 将文件作为命令的输入
- 管道(|):
ls -l | grep "log" # 列出文件并筛选包含 "log" 的行
cat 日志文件 | wc -l # 统计日志文件行数
3. 打包与压缩
- tar(打包工具,不压缩):
tar -cvf 包名.tar 目录/文件 # 打包(c=创建,v=显示过程,f=指定文件名)
tar -xvf 包名.tar # 解包(x=提取)
- 常用压缩格式:
- bash
# gzip(压缩为 .tar.gz)
tar -zcvf 包名.tar.gz 目录/文件
tar -zxvf 包名.tar.gz # 解压
# bzip2(压缩为 .tar.bz2,压缩率更高)
tar -jcvf 包名.tar.bz2 目录/文件
tar -jxvf 包名.tar.bz2 # 解压
# zip/unzip(跨平台)
zip -r 包名.zip 目录 # 压缩目录(需加 -r)
unzip 包名.zip # 解压
4. 链接文件
- 软链接(符号链接,类似快捷方式):
ln -s 源文件 链接名 # 创建软链接(删除源文件后链接失效)
- 硬链接(多个名称指向同一物理文件):
ln 源文件 链接名 # 创建硬链接(不能跨文件系统,不能链接目录)
七、文件系统相关工具
1. 查看磁盘空间:df
df -h # 以人性化格式显示各分区空间使用情况
2. 查看目录大小:du
du -sh 目录 # 查看目录总大小(s=汇总,h=人性化显示)
du -lh --max-depth=1 目录 # 查看目录下一级子目录大小
3. 文件描述符(进阶)
- Linux 中每个进程打开的文件对应一个数字(0 = 标准输入,1 = 标准输出,2 = 标准错误)。
- 重定向错误输出:命令 2> 错误日志.txt 或 命令 &> 所有输出.txt。
八、最佳实践与注意事项
- 路径写法:绝对路径:从根目录开始(如 /home/user/file.txt)。相对路径:从当前目录开始(如 ../data/report.csv)。
- 危险操作:避免在根目录(/)直接执行 rm -rf,防止误删系统文件。重要文件修改前先备份:cp 原文件 原文件.bak。
- 隐藏文件:以 . 开头的文件为隐藏文件(如 .bashrc),需用 ls -a 查看。
- 权限最小化原则:给文件 / 目录分配刚好足够的权限,避免安全风险(如目录通常设为 755,文件设为 644)。
九、总结
Linux 文件操作是系统管理的核心,掌握以下关键点可高效工作:
- 基础命令:ls/cd/mkdir/rm/cp/mv 是日常操作的基石。
- 权限管理:理解 r/w/x 含义,合理使用 chmod/chown。
- 内容处理:cat/more/less/grep 用于查看和过滤文本。
- 高级技巧:通配符、管道、链接、压缩等提升效率。
通过不断实践和总结,你会逐渐从 “命令记忆” 过渡到 “灵活组合”,成为 Linux 文件操作的高手!
相关推荐
- Nginx的http块sendfile,keepalive_timeout的配置指令说明,
-
sendfile是用来设置Ngnix服务的一种静态资源的写法sendfile:用来设置Nginx服务器是否使用sendfile()传输文件,该属性可以大大提高Nginx处理静态资源的性能这里send...
- Docker安装和配置Nginx(docker-compose部署nginx)
-
下载镜像dockerpullnginx检查Nginx镜像dockerimages创建挂载目录mkdir-p/home/docker-nginx/confmkdir-p/home/doc...
- 记:Nginx 如何配置SSL证书(nginx添加ssl证书)
-
引言最近,有几个其他项目团队的同事问了我几个类似问题:“钦哥,我们微信小程序微信支付,怎么回调不没反应?”“钦哥,我们的项目怎么无法通过https访问的?”然后就有想把配置ssl证书的过程,记录一...
- 多项目nginx部署配置(nginx多站点配置示例)
-
在前后端分离的项目中,前端部署大部分都采用nginx部署。在我参与的一个项目中,后台管理前端和业务应用前端是作为两个独立项目开发的。以往部署时通过不同端口来访问这两个项目,这就导致前端存储的token...
- NGINX最佳缓存配置策略(nginx最佳缓存配置策略有哪些)
-
Nginx可以配置的参数有很多,今天我们来看一下Nginx的缓存如何配置。no-cache和no-store“no-cache”表示必须先与服务器确认返回的响应是否发生了变化,然后才能使用该响应来满足...
- 通过 docker 学习 nginx,附全部配置及 API 测试,使用 apifox 直接打开
-
本篇文章以前端的视角,介绍下nginx的常见配置,并通过docker的方式学习nginx,这保证所有实例配置都能正常运行。我将本文所有关于docker/nginx的配置放置在simple...
- nginx配置负载均衡 以及宕机了后,怎么配置高可用
-
Nginx负载均衡配置是一个分发请求的过程。可以通过将同一个服务的多个实例配置到不同的服务器上,通过Nginx代理请求,将请求分发到这些实例上实现负载均衡。下面详细介绍Nginx负载均衡的配置过程和宕...
- nginx反向代理加https证书和自动跳转配置
-
nginx反向代理加https证书和自动跳转配置如果对运维课程感兴趣,可以在b站上搜索我的账号:运维实战课程,可以关注我,学习更多免费的运维实战技术视频1.机器规划:nginx代理机器:192.16...
- 【Nginx基础】Nginx常见负载均衡策略配置示例
-
下面是一些常用的Nginx负载均衡策略及其配置示例:轮询(RoundRobin)这是默认的负载均衡策略,它将请求依次分配给不同的后端服务器。upstreambackend{server...
- nginx中配置固定的JSON响应(nginx指定conf)
-
前提在进行性能测试时,使用mock接口是一种非常有效的方法,可以帮助您模拟真实服务的行为,从而避免对外部系统的依赖。使用Nginx作为mock接口的返回源不仅可以快速配置,还能确保mock接口本身不...
- Nginx基本安全配置(防盗连、隐藏版本号、防嵌套等)
-
在生产环境中nginx有很多安全方案,我在为生产环境部署中得到很多经验,收集到的一些常用配置,简单记录一下。安装Nginx正常安全Nginx大家应该都会,但是各位要知道在安全要求很高的生产环境中,是无...
- nginx如何配置跨域(nginx配置解决跨域)
-
要在Nginx中配置跨域,可以使用add_header指令来添加Access-Control-Allow-*头信息,如下所示:location/api{if($reques...
- Nginx合集-限流配置方案参考(nginx lua限流)
-
Nginx为我们提供了请求限制模块(ngx_http_limit_req_module)、基于令牌桶算法的流量限制模块(ngx_stream_limit_conn_module),可以方便的控制令牌速...
- 韩国站群服务器Nginx反向代理多IP配置指南
-
在站群服务器的运营中,Nginx反向代理技术如同一座智能调度中心,既能隐藏真实服务器架构,又能实现流量精准分发。尤其对于部署在韩国数据中心的站群而言,合理配置多IP反向代理,可显著提升SEO安全性与服...
- Nginx配置前后端服务(nginx配置前端页面部署)
-
nginx安装完成后,可以通过命令查看配置文件nginx-t配置文件nginx.conf,是总的配置,有的人会把配置全部配置到这个文件中,如果服务很多,这个文件变得非常庞大,我见过一个配置很大的,在...
- 一周热门
- 最近发表
-
- Nginx的http块sendfile,keepalive_timeout的配置指令说明,
- Docker安装和配置Nginx(docker-compose部署nginx)
- 记:Nginx 如何配置SSL证书(nginx添加ssl证书)
- 多项目nginx部署配置(nginx多站点配置示例)
- NGINX最佳缓存配置策略(nginx最佳缓存配置策略有哪些)
- 通过 docker 学习 nginx,附全部配置及 API 测试,使用 apifox 直接打开
- nginx配置负载均衡 以及宕机了后,怎么配置高可用
- nginx反向代理加https证书和自动跳转配置
- 【Nginx基础】Nginx常见负载均衡策略配置示例
- nginx中配置固定的JSON响应(nginx指定conf)
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)
- nginx配置 解析 (37)