Linux文件元信息完全指南:权限、链接与时间属性

Linux文件元信息完全指南:权限、链接与时间属性

关键词inode SUID/SGID 硬链接/软链接 文件时间戳 权限管理


一、文件权限体系
  1. 基础权限(9位标识)

    bash 复制代码
    -rwxr-xr--  # ls -l 输出示例
    • 三组权限 :拥有者(u)/所属组(g)/其他用户(o)
    • 权限值
      • r (读) = 4
      • w (写) = 2
      • x (执行) = 1
  2. 特殊权限(高位标识)

    权限位 作用场景 效果 设置命令
    SUID (4) 可执行文件 执行时以文件所有者 身份运行 (e.g. /usr/bin/passwd) chmod u+s file
    SGID (2) 可执行文件 执行时以文件所属组身份运行 chmod g+s file
    目录 新建文件自动继承目录的所属组(覆盖用户主组) chmod g+s dir/
    Sticky Bit (1) 目录 用户仅能删除自己创建的文件 (e.g. /tmp) chmod +t dir/

    权限显示

    • SUID: -rwsr-xr-x
    • SGID: -rwxr-sr-x
    • Sticky: drwxrwxrwt

二、文件链接机制
类型 本质 特点 命令
硬链接 同一inode的多个路径 1. 与源文件inode相同 2. 不可跨文件系统 3. 删除源文件不影响链接 ln source link
软链接 独立inode的指针文件 1. 存储源文件路径 2. 可跨文件系统 3. 源文件删除后链接失效 ln -s source link

显示标识

bash 复制代码
-rw-r--r-- 2 user group 4096 Jan 1 10:00 hardlink  # 硬链接(第二列为链接计数)
lrwxrwxrwx 1 user group   11 Jan 1 10:00 softlink -> source.txt  # 软链接

三、用户与组信息
  1. 元数据存储位置

    • 文件所有者st_uid → 映射 /etc/passwd
    • 文件所属组st_gid → 映射 /etc/group
  2. 关键命令

    bash 复制代码
    stat filename      # 查看文件元信息
    ls -n filename     # 显示UID/GID而非用户名

四、文件大小与磁盘占用
c 复制代码
struct stat {
    off_t st_size;    // 文件实际大小(字节)
    blkcnt_t st_blocks; // 占用磁盘块数量(通常每块512字节)
};

示例

  • 1字节文件可能占用4KB磁盘空间(受块大小影响)

五、时间戳详解
类型 简称 触发条件 查看命令
Access atime 读取文件内容 ls -lu
Modify mtime 修改文件内容 ls -l
Change ctime 修改元信息(权限/所有者等) ls -lc

时间转换代码示例(C语言):

c 复制代码
#include <sys/stat.h>
#include <time.h>

struct stat sb;
stat("file.txt", &sb);

struct tm *timeinfo = localtime(&sb.st_mtime);  // 解析mtime
char buffer[80];
strftime(buffer, 80, "%Y-%m-%d %H:%M:%S", timeinfo);  // 格式化为字符串
printf("Last Modified: %s\n", buffer);

六、最佳实践
  1. 权限安全
    • 慎用SUID位,避免普通用户获得root权限
    • 共享目录使用SGID+Sticky Bit(如团队协作目录)
  2. 时间戳优化
    • 频繁读场景可关闭atime提升性能(mount -o noatime
  3. 链接选择
    • 备份用硬链接(节省空间),快捷访问用软链接

相关推荐
ASS-ASH5 分钟前
快速处理虚拟机磁盘扩容问题
linux·数据库·vmware·虚拟机·磁盘扩容
AI_56785 分钟前
零基础学Linux:21天从“命令小白”到独立部署服务器
linux·服务器·人工智能·github
江湖有缘7 分钟前
Fenrus + Docker 实战:构建简洁高效的浏览器新标签页
运维·docker·容器
乾元7 分钟前
如何把 CCIE / HCIE 的实验案例改造成 AI 驱动的工程项目——从“实验室能力”到“可交付系统”的完整迁移路径
大数据·运维·网络·人工智能·深度学习·安全·机器学习
不染尘.8 分钟前
Linux基本概述
linux·windows·centos·ssh
lpfasd1239 分钟前
宝塔面板(BT Panel)集成雷池 SafeLine WAF(社区版)
运维
weixin_4462608510 分钟前
XPipe: 轻松访问你的服务器基础设施 [特殊字符]
运维·服务器
TTGGGFF11 分钟前
GLM-4V-9B 视觉多模态模型本地部署教程【保姆级教程】
linux·运维·服务器·图文对话
r***013811 分钟前
Nginx代理到https地址忽略证书验证配置
运维·nginx·https
消失的旧时光-194314 分钟前
函数指针 + 结构体 = C 语言的“对象模型”?——从 C 到 C++ / Java 的本质统一
linux·c语言·开发语言·c++·c