linux的chown和chmod命令

最近对root用户做了限制,之前在Linux上的使用kettle,直接用root用户的;现在要用普通用户来使用kettle。所以直接把kettle相关路径的文件主直接改成普通用户datauser,再把原来/root/.kettle 目录下的文件(主要是repositories.xml 资源库的相关配置信息)都cp到/home/datauser 长时间不用有点忘了,顺便总结下 Linux赋权限相关命令。

chown命令:
chown change owner的缩写,更改与文件关联的所有者或所属组
语法: chown [-f][-h][-R] Owner:Group { File ... | Directory ... }
chown -R [-f ][-H| -L| -P] Owner:Group { File ... | Directory ... }
chown命令将 File 参数指定的文件的所有者更改为 Owner 参数指定的用户;参数-H、-L 和 -P 标志是互斥的,指定不止一个时虽然不认为是错误的;但是一般是指定的最后一个参数标志确定命令操作。

chown参数:
-c(-change):显示更改的部分的信息 
-f:忽略错误信息,不显示错误信息 。
-h:只对符号链接的文件做修改,而不更改其他任何相关文件;当遇到符号链接而未指定-h标志时,chown命令更改链接指向的文件或目录的所有权,而非链接本身的所有权。
-H:如果也指定了-R 选项,并且引用类型目录的文件的符号链接在命令行上指定,chown 变量会更改由符号引用的目录的用户标识(和组标识,如果已指定)和所有在该目录下的文件层次结构中的所有文件。
-L:如果也指定了-R 选项,并且引用类型目录的文件的符号在命令行上指定或在遍历文件层次结构期间遇到,chown 命令会更改由符号链接引用的目录的用户标识(和组标识,如果已指定)和在该目录之下的文件层次结构中的所有文件。
-P:如果也指定了-R 选项并且符号链接在命令行上指定或者在遍历文件层次结构期间遇到,则如果系统支持该操作,则 chown 命令会更改符号链接的所有者标识(和组标识,如果已指定)。chown 命令不会执行至文件层次结构的任何其它部分的符号链接。
-R:递归处理,更改每个文件的所有权。
  • 例如将目录/opt/data-integration下的所有文件、子目录的所有者改成datauser 用命令chown -R datauser:datauser /opt/data-integration
  • 例如将文件file所有者改为hadoop、群组改为root 用命令 chown hadoop:root file.txt
  • 例如将文件file所有者改为hadoop 用命令chown hadoop: file
  • 例如将文件file的所属群组改为users 用命令chown :users file

chmod命令:
linux文件权限有三级,依次为所有者u、群组g、其他o

  • 其中u(user)表示该文件的所有者,g(group)表示与该文件的所有者属于同一个群组,o(other)表示其他以外的人,a(all)表示这三者皆是。
  • + 表示增加权限,- 表示取消权限,= 表示唯一设定权限。
  • r 表示可读取 对应4w 表示可写入对应2x 表示可执行 对应1X 表示该文件有子目录;若要rwx属性则4+2+1=7; 若要rw-属性则4+2=6; 若要r-x属性则4+1=5。
  • 例如将文件file设为所有人可以读、写、执行 可用命令chmod a=rwx file 或者chmod 777 file
  • 例如将文件file设为除所有者外其他人只能读的权限,可用命令chomod 744
  • 例如将当前文件夹下的所有文件的权限都设为777 用命令chmod -R 777
  • 例如将文件file设为所有人可读 可用命令chmod ugo+r file或者 chmod a+r file
  • 例如将文件file设置与其所属同一个群组的可写入,但其他以外的人则不可写入 可用命令chmod ug+w,o-w file
  • 例如将当前目录下所有文件与子目录皆设为任何人可读取 可用命令chmod -R a+r dir/*
chmod其他参数说明:
-c : 若该文件权限确实已经更改,才显示其更改动作
-f : 若该文件权限无法被更改也不显示错误
-v : 显示权限变更的详细信息
-R : 对当前目录下的所有文件与子目录进行相同的权限变更(即以递回的方式逐个变更)

cp 命令:
linux复制某个目录dir1下的所有文件到另一个目录dir2中:
若dir2目录不存在,用命令 cp -r dir1 dir2
若dir2目录已存在,用命令cp -rf dir1/. dir2 ,如果目标目录下存在文件需要先删除,不然需要一个一个确认很麻烦,rm -rf /dir2/* ,做删除操作很危险,一定要确认好了再删,或者直接把 dir2 文件夹 mv 到 /tmp 目录下 统一删除 避免风险。

cp 命令参数:
-a: 效果和同时指定"-dpR"参数相同;
-d:当复制符号连接时,把目标文件或目录也建立为符号连接,并指向与源文件或目录连接的原始文件或目录;
-f:force 强制的意思,强行复制文件或目录,不论目标文件或目录是否已存在;
-i:覆盖既有文件之前先询问用户,回答y时目标文件将被覆盖,是交互式拷贝;
-l:对源文件建立硬连接,而非复制文件;
-p:保留源文件或目录的属性;
-R/r:递归处理,将指定目录下的所有文件与子目录一并处理;
-s:对源文件建立符号连接,而非复制文件;
-u:使用这项参数后只会在源文件的更改时间较目标文件更新时或是名称相互对应的目标文件并不存在时,才复制文件;
-S:在备份文件时,用指定的后缀“SUFFIX”代替文件的默认后缀;
-b:覆盖已存在的文件目标前将目标文件备份;
-v:详细显示命令执行的操作。
发布了52 篇原创文章 · 获赞 7 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/hyfstyle/article/details/103696953