linux chmod,chown命令详解

linux chmod,chown命令详解

指令名称:chmod

使用权限 : 所有使用者

使用方式 : chmod [-cfvR] [--help] [--version] mode file... 说明 : Linux/Unix 的档案存取权限分为三级 : 档案拥有者、群组、其他。

利用 chmod 可以藉以控制档案如何被他人所存取。

mode 权限设定字串,格式如下 : [ugoa...][[+-=][rwxX]...][,...]

u:表示该档案的拥有者 g: 表示与该档案的拥有者属于同一个群体(group)o:表示其他以外的人 a: 表示这三者皆是

+: 表示增加权限、- 表示取消权限、= 表示唯一设定权限。 r:表示可读取,w 表示可写入,x 表示可执行,X 表示只有当该档案是个子目录或者该档案已经被设定过为可执行。 -c: 若该档案权限确实已经更改,才显示其更改动作 -f : 若该档案权限无法被更改也不要显示错误讯息 -v: 显示权限变更的详细资料 -R: 对目前目录下的所有档案与子目录进行相同的权限变更(即以递回的方式逐个变更) --help: 显示辅助说明 --version: 显示版本

示例1:

将档案 ymq.txt 设为所有人皆可读取 :

chmod ugo+r ymq.txt   

将档案 ymq.txt 设为所有人皆可读取 :

chmod a+r ymq.txt   

将档案 ymq1.txt 与 ymq2.txt 设为该档案拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :

chmod ug+w,o-w ymq1.txt ymq2.txt  

将 ymq.py 设定为只有该档案拥有者可以执行 :

chmod u+x ymq.py   

将目前目录下的所有档案与子目录皆设为任何人可读取 :

chmod -R a+r *   

此外chmod也可以用数字来表示权限如 chmod 777 file

语法为:chmod abc file 其中a,b,c各为一个数字,分别表示UserGroup、及Other的权限

r=4,w=2,x=1

若要rwx属性则4+2+1=7 若要rw-属性则4+2=6 若要r-x属性则4+1=5

示例2:

chmod a=rwx file
#和
chmod 777 file  
#效果相同
chmod ug=rwx,o=x file
#和
chmod 771 file
#效果相同

若用chmod 4755 filename可使此程式具有root的权限

指令名称:chown

使用权限 : root

使用方式 : chown [-cfhvR] [--help] [--version] user[:group] file... 说明 : Linux/Unix 是多人多工作业系统,所有的档案皆有拥有者。利用 chown 可以将档案的拥 有者加以改变。一般来说,这个指令只有是由系统管理者(root)所使用,一般使用者没有权限可以 改变别人的档案拥有者,也没有权限可以自己的档案拥有者改设为别人。只有系统管理者(root)才 有这样的权限。

user: 新的档案拥有者的使用者 ID group: 新的档案拥有者的使用者群体(group) -c-change:作用与-v相似,但只传回修改的部分 -f–quiet或–silent:不显示错误信息 -h–no-dereference:只对符号链接的文件做修改,而不更改其他任何相关文件 -R-recursive:递归处理,将指定目录下的所有文件及子目录一并处理 -v–verbose:显示指令执行过程 –dereference:作用和-h刚好相反 –help:显示在线说明 –reference=<参考文件或目录>:把指定文件或目录的所有者与所属组,统统设置成和参考文件或目录的所有者与所属组相同 –version:显示版本信息

示例1:

将档案 file1.txt 的拥有者设为 users 群体的使用者 jessie :

chown jessie:users file1.txt   

将目前目录下的所有档案与子目录的拥有者设为

chown -R ymq(所属用户) : ymqgroup(所属用户组名) * (要更改的文件路径)

chown [-R] [用户名称] [文件或目录] chown [-R] [用户名称:组名称] [文件或目录]

chown -R ymq:ymqgroup *   

rwx分别表示UserGroup、及Other的权限。

-rw------- (600) -- 只有属主有读写权限 -rw-r–r– (644) – 只有属主有读写权限;而属组用户和其他用户只有读权限 -rwx------ (700) -- 只有属主有读、写、执行权限 -rwxr-xr-x (755) – 属主有读、写、执行权限;而属组用户和其他用户只有读、执行权限 -rwx--x--x (711) -- 属主有读、写、执行权限;而属组用户和其他用户只有执行权限 -rw-rw-rw- (666) – 所有用户都有文件读、写权限。这种做法不可取 -rwxrwxrwx (777`) – 所有用户都有读、写、执行权限。更不可取的做法

示例2:

test3.txt文件的属主改为test用户。

# ls -l test3.txt  
-rw-r–r– 1 test root 0 2017-08-20 9:59 test3.txt  
# chown test:root test3.txt  
# ls -l test3.txt  
-rw-r–r– 1 test root 0 2017-08-20 9:59  

示例3:

chown所接的新的属主和新的属组之间可以使用:连接,属主和属组之一可以为空。如果属主为空,应该是“:属组”;如果属组为空,“:”可以不用带上。

# ls -l test3.txt  
-rw-r–r– 1 test root 0 2017-08-20 9:59 test3.txt  
  
# chown :test test3.txt <==把文件test3.txt的属组改为test  
# ls -l test3.txt  
-rw-r–r– 1 test test 0 2017-08-20 9:59 test3.txt  

示例4:

chown也提供了-R参数,这个参数对目录改变属主和属组极为有用,可以通过加 -R参数来改变某个目录下的所有文件到新的属主或属组。

# ls -l testdir <== 查看testdir目录属性  
drwxr-xr-x 2 usr root 0 2009-10-56 10:38 testdir/ <==文件属主是usr用户,属组是 root用户  
# ls -lr testdir <==查看testdir目录下所有文件及其属性  
total 0  
-rw-r–r– 1 usr root 0 2017-08-20 10:38 test1.txt  
-rw-r–r– 1 usr root 0 2017-08-20 10:38 test2.txt  
-rw-r–r– 1 usr root 0 2017-08-20 10:38 test3.txt  
# chown -R test:test testdir/ <==修改testdir及它的下级目录和所有文件到新的用户和用户组  
# ls -l testdir  
drwxr-xr-x 2 test test 0 2017-08-20 10:38 testdir/  
# ls -lr testdir  
total 0  
-rw-r–r– 1 test test 0 2017-08-20 10:38 test1.txt  
-rw-r–r– 1 test test 0 2017-08-20 10:38 test2.txt  
-rw-r–r– 1 test test 0 2017-08-20 10:38 test3.txt  

Contact

  • 作者:鹏磊
  • 出处:http://www.ymq.io
  • Email:admin@souyunku.com
  • 版权归作者所有,转载请注明出处
  • Wechat:关注公众号,搜云库,专注于开发技术的研究与知识分享

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程坑太多

『中级篇』play with docker 的使用(44)

Marcos 和 Jonathan 还带来了另一个炫酷的功能就是可以在 PWD 实例中通过拖放文件的方式将 Dockerfile 直接上传到 PWD 窗口。

11830
来自专栏about云

Flume+Kafka收集Docker容器内分布式日志应用实践

问题导读: 1、如何设计Flume+Kafka收集架构? 2、如何修改Docker内配置文件? 3、如何进行Flume配置? 4、如何定制RollingByTy...

765120
来自专栏EAWorld

Resteasy ,从学会使用到了解原理

1、背景知识 1.1)了解Rest是什么? 1.2)了解JAX-RS是什么? 1.3)RestEasy简介 2、手把手教你使...

30440
来自专栏CaiRui

linux开机流程

1.加载BIOS 当你打开计算机电源,计算机首先会加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始找到它。这是因为BIOS中包含了CPU的...

19270
来自专栏繁花云

关于电脑无法开机或无法启动的几种可能和解决方案

(转载自http://www.bios.net.cn/e/DoPrint/?classid=34&id=650 )

11100
来自专栏walterlv - 吕毅的博客

制作 Windows 10 安装盘,解决大于 4GB 的 Windows 10 镜像在 UEFI 模式下的安装问题

2018-02-22 14:14

31310
来自专栏大魏分享(微信公众号:david-share)

技术派:谁说API网关只能集成REST APIs?

21430
来自专栏编程坑太多

『中级篇』play with docker 的使用(44)

Marcos 和 Jonathan 还带来了另一个炫酷的功能就是可以在 PWD 实例中通过拖放文件的方式将 Dockerfile 直接上传到 PWD 窗口。

6910
来自专栏最新技术

使用Eclipse MicroProfile(更新版)构建您的下一个微服务

本快速教程将向您展示如何使用最新版本的Eclipse MicroProfile API构建您的下一个微服务。这是一篇基于以前John D Ament 的文章的修...

88520
来自专栏difcareer的技术笔记

breakpad: Native crash 日志收集工具前言正题breakpad工作原理项目集成

现在大部分应用都会有Java层的崩溃日志收集机制,一般就是程序crash后,展示一个上报界面,用户点击就上传了。 但是Native程序crash了,很少有做处...

17820

扫码关注云+社区

领取腾讯云代金券