常见文件目录
各大发行版基本一致,遵循的是通用的FHS(Filesystem Hierarchy Standard)约定,(个别子目录如 lib64、multiarch 名称可能略有不同)
1. 开发者部署模板
用一个假想应用myapp为例,展示其在Linux系统中应该如何分布文件和目录。
🏗️ myapp 部署模板(FHS 标准 + systemd)
# 核心可执行文件
/usr/local/bin/myapp # 主程序(编译/安装好的二进制)
# 配置文件(小而精,可编辑)
/etc/myapp/
├─ config.yml # 主配置
└─ logging.conf # 日志配置 (如 log4j, logback, python logging)
# systemd 单元文件(管理启动/停止)
/etc/systemd/system/myapp.service # 自定义服务单元
# 持久化数据(需备份)
/var/lib/myapp/
├─ db.sqlite # 内置数据库(如 SQLite)
└─ state.json # 应用运行状态、索引文件
# 日志(需轮转管理 logrotate/journald)
/var/log/myapp/
├─ myapp.log # 主日志
└─ error.log # 错误日志
# 缓存(可删除,会重建)
/var/cache/myapp/
├─ tmp_result/ # 临时计算结果
└─ images/ # 下载或生成的图片缓存
# 运行时文件(随重启清空)
/run/myapp/
├─ myapp.pid # 进程 PID 文件
└─ myapp.sock # Unix socket (如 FastCGI/IPC)
# 临时文件(不跨重启)
/tmp/myapp.* # 中间数据、临时输出
2. 精简版
/
├─ ⚙️ etc/ # 系统配置(小而精)
│ └─ 📄 <appname>/ # 你的应用配置 (config.yml, app.conf)
│
├─ 🏠 home/ # 用户根目录
│ └─ 👤 username/.local/ # 用户级安装 (bin, lib, share, config, cache)
│
├─ 👑 root/ # root 用户根目录
│
├─ 📦 usr/ # 系统安装的软件(包管理器管理)
│ ├─ 🛠️ bin/ # 普通可执行程序 (gcc, git)
│ ├─ 🔧 sbin/ # 管理命令
│ ├─ 📚 lib/ # 系统库
│ ├─ 📖 share/ # 数据资源 (man, icons, locale)
│ └─ 📦 local/ # 本机编译安装的软件
│ ├─ 🛠️ bin/ # 手工编译安装的可执行文件
│ ├─ 📚 lib/ # 本机库
│ ├─ 📄 etc/ # 本机配置
│ └─ 📖 share/ # 本机数据资源
│
├─ 📦 opt/ # 第三方大软件(自带依赖)
│ └─ 📂 <vendor>/<app>/ # 整个应用目录 (bin, lib, config, static)
│
├─ 🔄 var/ # 变动数据(日志、缓存、状态)
│ ├─ 📝 log/<app>/ # 应用日志
│ ├─ 💾 lib/<app>/ # 数据库、持久化状态
│ ├─ 🗂️ cache/<app>/ # 缓存文件
│ └─ 📬 spool/<svc>/ # 队列数据 (邮件、打印、任务)
│
├─ 🚀 run/ # 运行时状态(随重启清空)
│ └─ 📄 <appname>/{pid,sock} # PID 文件、socket
│
└─ 🗑️ tmp/ # 临时文件(重启清空)
└─ 🗂️ <app>.* # 中间结果、临时缓存
3. 详细版
/
├─ 🛠️ bin/ # 基本用户命令 (ls, cp, mv)
├─ 🔧 sbin/ # 系统管理命令 (reboot, iptables)
├─ 💻 boot/ # 引导文件 (内核 vmlinuz, grub)
├─ 📀 dev/ # 设备文件 (/dev/sda, /dev/tty)
├─ ⚙️ etc/ # 系统配置 (/etc/hosts, passwd, fstab)
│ ├─ 🌐 network/ # 网络配置
│ ├─ 🔄 systemd/ # systemd 配置
│ └─ 🖥️ X11/ # 图形界面配置
├─ 🏠 home/ # 用户家目录 (/home/user)
│ ├─ 👤 user1/
│ └─ 👤 user2/
├─ 👑 root/ # root 用户家目录
├─ 📚 lib/ # 系统库
├─ 📚 lib64/ # 64 位系统库
├─ 💽 media/ # 移动介质挂载点 (U盘, 光驱)
├─ 📂 mnt/ # 临时挂载点
├─ 📦 opt/ # 第三方/大型软件 (/opt/google)
├─ 🔍 proc/ # 内核与进程信息 (/proc/cpuinfo)
├─ 🚀 run/ # 运行时状态 (PID, socket)
├─ 🌐 srv/ # 服务数据目录 (网站, FTP)
├─ 🧩 sys/ # 硬件与内核信息 (/sys/class)
├─ 🗑️ tmp/ # 临时文件 (重启清空)
├─ 📦 usr/ # 用户应用和库 (绝大部分软件)
│ ├─ 🛠️ bin/ # 用户命令 (gcc, python)
│ ├─ 🔧 sbin/ # 管理命令 (apachectl)
│ ├─ 📚 lib/ # 共享库
│ ├─ 📑 include/ # 头文件
│ ├─ 📖 share/ # 架构无关数据 (man, locale, icons)
│ └─ 📦 local/ # 本机安装软件 (结构同 /usr)
│ ├─ 🛠️ bin/
│ ├─ 📚 lib/
│ ├─ ⚙️ etc/
│ └─ 📖 share/
├─ 🔄 var/ # 变动数据 (日志, 缓存, DB)
│ ├─ 📝 log/ # 日志文件
│ ├─ 💾 lib/ # 服务持久化数据 (DB, 索引)
│ ├─ 🗂️ cache/ # 缓存 (apt, yum)
│ ├─ 📬 spool/ # 队列 (邮件, 打印, cron)
│ ├─ 🗑️ tmp/ # 跨重启的临时文件
│ └─ 🚀 run -> /run # 兼容符号链接
└─ 🛟 lost+found/ # 文件系统修复时的残片
/bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。👉 不要放自家程序。发行版维护/sbin:s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序./sbin -> usr/sbin。👉 不要放自家程序。发行版维护/usr:这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。👉 打包分发(deb/rpm)时:把可执行文件放/usr/bin,库放/usr/lib*,数据放/usr/share/<app>,头文件放/usr/include(若公开开发包)。/usr/bin:系统用户使用的应用程序。/usr/sbin:超级用户使用的比较高级的管理程序和系统守护程序。/usr/src:内核源代码默认的放置目录。/usr/lib*:共享库/usr/share:与架构无关的数据(man、示例、icons、locale)/usr/include:头文件。/usr/local:本机手工安装的软件镜像/usr结构,避免与发行版冲突。- 👉 自行编译/安装的工具放这里:
/usr/local/bin、/usr/local/lib*、/usr/local/share/<app>。 好处:一键清理、区分“官方包 vs 本机安装”。
- 👉 自行编译/安装的工具放这里:
/opt/:这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下,默认是空的。自包含的大型或第三方应用(如opt/vendor/app),内部自带libs、runtime。 👉 商业软件、Node/Python 整个应用目录、前后端一体分发可放/opt/<vendor>/<app>;再符号链接主可执行到/usr/local/bin/<app>便于 PATH使用。/etc:这个目录用来存放所有的系统管理所需要的配置文件和子目录。你的应用的系统级默认配置:/etc/<app>/config.yml(只存配置,不存数据/密钥库)。 systemd 配置覆写放/etc/systemd/system/<app>.service(或 drop-in:<service>.d/*.conf)。/var:这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下,包括各种日志文件。 👉 你的应用把日志/状态/缓存分别放在对应子目录。确保权限与轮转(logrotate 或 journald)。/var/log/<app>/:日志/var/lib/<app>/:持久化状态(DB、索引、migrations 标记等)/var/cache/<app>/:可丢弃缓存/var/spool/<service>/:排队/待处理数据(邮件、打印、任务队列)/var/tmp/:跨重启保留的临时文件
/run/(早期叫/var/run):运行时状态(tmpfs,随重启清空)。 👉 PID 文件、Unix 套接字、锁文件、短期运行时数据:/run/<app>/{app.pid,app.sock}。/tmp:这个目录是用来存放一些临时文件的(常在重启时清除)。 👉 临时中间文件、下载碎片等;不存需要保留的内容。 需要跨重启临时数据就用/var/tmp。/srv/:该目录存放一些服务启动之后需要提取的数据,如服务对外提供的数据根(如网站、FTP)。 👉 如你要维护“站点根目录”:/srv/www/<site>/。/home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。👉 用户级安装与配置:~/.local/bin:个人可执行(加入 PATH)~/.config/<app>/:用户配置(XDG)~/.cache/<app>/:用户缓存~/.local/share/<app>/:用户数据
/lib及/lib64/:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。/lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。/media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。/mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。/dev:dev是Device(设备)的缩写, 该目录下存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。/proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件/boot:这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。/sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。sysfs文件系统集成了下面3种文件系统的信息:针对进程信息的proc文件系统、针对设备的devfs文件系统以及针对伪终端的devpts文件系统。该文件系统是内核设备树的一个直观反映。当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。/root:该目录为系统管理员,也称作超级权限者的用户主目录。/selinux:这个目录是Redhat/CentOS所特有的目录,Selinux是一个安全机制,类似于windows的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。