linux中 umask 命令

Umask

Umask(User File Creation Mode Mask)是Linux系统中的一项命令,用于设定新创建文件和目录的默认权限。

一、umask的作用

Umask通过掩码操作,限制新文件和目录的访问权限。在Linux中,所有的文件和目录都被分配了一组默认权限。新文件的默认权限通常为666(即所有用户都有读和写权限,但没有执行权限),而新目录的默认权限通常为777(即所有用户都有读、写和执行权限)。然而,实际创建文件或目录时,Umask会从这些默认权限中"减去"特定的权限,以限制文件或目录的访问权限。

二、umask的工作原理

Umask是一个三位的八进制数字,每一位都对应着不同的权限设置。每个数字表示文件或目录的权限掩码,可以用来"屏蔽"掉默认权限中的某些权限。例如,Umask 022会从默认权限中减去写权限(对于其他用户),因此新文件的权限会被设置为644(用户具有读/写权限,其他用户仅具有读权限),而新目录的权限会被设置为755(用户具有读/写/执行权限,其他用户具有读/执行权限)。

三、查看和修改umask值

  1. 查看当前umask值:
    可以在终端中直接输入umask命令,然后按Enter键,系统将以八进制方式显示当前的umask值。
    也可以使用umask -S命令以符号方式显示当前的umask值,例如u=rwx,g=rx,o=rx。
  2. 修改umask值:
    可以使用umask [mode]命令来设置新的umask值,其中[mode]是一个三位八进制数,表示新的权限掩码。
    要永久更改umask值,可以编辑bash配置文件(如.bashrc或.profile),在文件中添加umask [mode]命令,然后保存文件并重新加载配置文件(使用source命令)。

四、umask值的计算

假设Umask值为022,如何计算文件和目录的权限呢?

文件权限 :默认权限为666(文件的最大权限),Umask 022代表减去"写权限"(对于其他用户)。因此,结果:666 - 022 = 644(即rw-r--r--)。
目录权限:默认权限为777(目录的最大权限),Umask 022代表减去"写权限"(对于其他用户)。因此,结果:777 - 022 = 755(即rwxr-xr-x)。

相关推荐
_下雨天.1 小时前
LVS负载均衡
服务器·负载均衡·lvs
小成202303202653 小时前
Linux高级02
linux·开发语言
mounter6253 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
++==4 小时前
Linux 进程间通信与线程同步技术详解:IPC 机制、线程 API、同步工具与经典同步问题
linux
特长腿特长4 小时前
centos、ubantu系列机的用户和用户组的结构是什么?具体怎么配置?用户组权限怎么使用?这篇文章持续更新,帮助你复习linux的基础知识
linux·运维·centos
zzzyyy5384 小时前
Linux环境变量
linux·运维·服务器
pluvium274 小时前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
无级程序员5 小时前
centos7 安装 llvm-toolset-7-clang出错的问题解决
linux·centos
kebeiovo5 小时前
atomic原子操作实现无锁队列
服务器·c++
赛博云推-Twitter热门霸屏工具5 小时前
Twitter运营完整流程:从0到引流获客全流程拆解(2026)
运维·安全·自动化·媒体·twitter