暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Chmod命令详解

王佐的运维笔记 2020-06-01
1300

chmod命令用来变更文件或目录的权限。在UNIX系统家族里,文件或目录权限的控制分别以读取、写入、执行3种一般权限来区分,另有3种特殊权限可供运用。用户可以使用chmod指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果用户对符号连接修改权限,其改变会作用在被连接的原始文件。

指令名称 : 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 : 显示版本
范例 :将文件 test1.txt 设为所有人皆可读取 :
chmod ugo+r test1.txt
将文件 test1.txt 设为所有人皆可读取 :
chmod a+r test1.txt
将文件 test1.txt 与 test2.txt 设为该文件拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :
chmod ug+w,o-w test1.txt test2.txt  
将 a.sh 设定为只有该文件拥有者可以执行 : 
chmod u+x a.sh 
将目前目录下的所有文件与子目录皆设为任何人可读取 :
chmod -R a+r *
此外chmod也可以用数字来表示权限如 chmod 777 file
语法为:chmod abc file
其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。
r=4,w=2x=1
若要rwx属性则4+2+1=7
若要rw-属性则4+2=6
若要r-x属性则4+1=5
范例:
chmod a=rwx file

chmod 777 file
效果相同
chmod ug=rwx,o=x file

chmod 771 file
效果相同
若用chmod 4755 filename可使此程序具有root的权限.
指令名称 : chown
使用权限 : root


使用方式 : chmod [-cfhvR] [--help] [--version] user[] file...
复制

说 明 : 

Linux/Unix 是多人多工作业系统,所有的文件皆有拥有者。利用 chown 可以将文件的拥有者加以改变。一般来说,这个指令只有是由 系统管理者(root)所使用,一般使用者没有权限可以改变别人的文件拥有者,也没有权限可以自己的文件拥有者改设为别人。只有系统管理者(root)才 有这样的权限。  


参数详解 :  

user: 新的文件拥有者的使用者
IDgroup: 新的文件拥有者的使用者群体
(group)-c: 若该文件拥有者确实已经更改,才显示其更改动作
-f: 若该文件拥有者无法被更改也不要显示错误讯息
-h: 只对于连结 (link)进行变更,而非该 link 真正指向的文件
-v: 显示拥有者变更的详细资料
-R: 对目前目录下的所有文件与子目录进行相同的拥有者 变更(即以递回的方式逐个变更)  
--help : 显示辅助说明  
--version : 显示版本
复制

 


范例 :  
将文件 test.txt 的拥有者设为 group1 群体的使用者 wangzuo :  

chown wangzuo:group1 test.txt
复制



将目前目录下的所有文件与子目录的拥有者皆设为 wangzuo 群体的使用者 group1 :  
chmod -R group1:wangzuo *
-rw------- (600) -- 只有属主有读写权限。
-rw-r--r-- (644) -- 只有属主有读写权限;而属组用户和其他用户只有读权限。
-rwx------ (700) -- 只有属主有读、写、执行权限。
-rwxr-xr-x (755) -- 属主有读、写、执行权限;而属组用户和其他用户只有读、执行权限。
-rwx--x--x (711) -- 属主有读、写、执行权限;而属组用户和其他用户只有执行权限。
-rw-rw-rw- (666) -- 所有用户都有文件读、写权限。这种做法不可取。
-rwxrwxrwx (777) -- 所有用户都有读、写、执行权限。更不可取的做法。
复制

以下是对目录的两个普通设定:  

drwx------ (700) - 只有属主可在目录中读、写。
drwxr-xr-x (755) - 所有用户可读该目录,但只有属主才能改变目录中的内容。
复制

运行 .sh 文件类型的文件:

用file命令测试一下看是什么类型的
file xxxx.sh
如果是Bourne-Again shell script 可以sh xxxx.sh 或者chmod +x xxxx.sh 再./xxx.sh
一般 .sh 的直接添加x(可执行属性) chmod +x xxx.sh 然后./xxx.sh就可以了
chmod是一个改变用户拥有指定文件的权限的命令.r:只读,w:写,x执行.也可以用数字


文章转载自王佐的运维笔记,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论