linux:chown用法详解

文章目录

  • [1. 描述](#1. 描述)
  • [2. 语法](#2. 语法)
  • [3. 参数](#3. 参数)
  • [4. 例子](#4. 例子)

1. 描述

chown 是 Linux 中用于更改文件或目录的所有者和所有者组的命令。

2. 语法

bash 复制代码
chown [选项] 所有者[:组] 文件名

详细用法:

bash 复制代码
Usage: chown [OPTION]... [OWNER][:[GROUP]] FILE...
  or:  chown [OPTION]... --reference=RFILE FILE...
Change the owner and/or group of each FILE to OWNER and/or GROUP.
With --reference, change the owner and group of each FILE to those of RFILE.

  -c, --changes          like verbose but report only when a change is made
  -f, --silent, --quiet  suppress most error messages
  -v, --verbose          output a diagnostic for every file processed
      --dereference      affect the referent of each symbolic link (this is
                         the default), rather than the symbolic link itself
  -h, --no-dereference   affect symbolic links instead of any referenced file
                         (useful only on systems that can change the
                         ownership of a symlink)
      --from=CURRENT_OWNER:CURRENT_GROUP
                         change the owner and/or group of each file only if
                         its current owner and/or group match those specified
                         here.  Either may be omitted, in which case a match
                         is not required for the omitted attribute
      --no-preserve-root  do not treat '/' specially (the default)
      --preserve-root    fail to operate recursively on '/'
      --reference=RFILE  use RFILE's owner and group rather than
                         specifying OWNER:GROUP values
  -R, --recursive        operate on files and directories recursively

The following options modify how a hierarchy is traversed when the -R
option is also specified.  If more than one is specified, only the final
one takes effect.

  -H                     if a command line argument is a symbolic link
                         to a directory, traverse it
  -L                     traverse every symbolic link to a directory
                         encountered
  -P                     do not traverse any symbolic links (default)

      --help     display this help and exit
      --version  output version information and exit

Owner is unchanged if missing.  Group is unchanged if missing, but changed
to login group if implied by a ':' following a symbolic OWNER.
OWNER and GROUP may be numeric as well as symbolic.

3. 参数

以下是chown命令常用的参数选项及其详细解释:

  1. -R, --recursive

    递归地改变文件及其目录内所有子文件和子目录的所有者和组。

    例如:chown -R user:group directory,将会改变directory及其内部所有文件和子目录的所有者和组。

  2. -h, --no-dereference

    只改变符号链接本身的所有者和组,而不是它指向的文件或目录。

    例如:chown -h user:group symlink,只改变符号链接syrmlink的所有者和组。

  3. -f, --silent, --quiet

    抑制错误信息,当chown尝试更改不存在的文件或目录时不会显示错误消息。

    例如:chown -f user:group file,如果file不存在,不会显示错误信息。

  4. -v, --verbose

    显示详细信息,显示更改了哪些文件的所有者和组。

    例如:chown -v user:group file,会输出更改file所有者和组的详细信息。

  5. --from=OWNER[:GROUP]

    只更改当前所有者和组与指定的所有者和组匹配的文件。

    例如:chown --from=user:group newowner:newgroup file,只会更改当前所有者为user且组为groupfile

  6. --reference=REF

    使用引用文件的所有者和组来更改文件。

    例如:chown --reference=ref_file file,将会把file的所有者和组改成与ref_file相同的。

  7. --no-preserve-root

    默认情况下,如果用户不是超级用户(root),则不允许指定/作为文件名。此选项取消此限制。

    例如:chown --no-preserve-root user:group /,允许非root用户尝试更改根目录的所有者和组。

  8. --preserve-root

    强制chown检查是否为根用户(root),如果不是,则拒绝任何尝试更改根目录(/)的行为。这是默认行为。

  9. --help

    显示帮助信息。

  10. --version

    显示版本信息。

使用chown命令时,可以将所有者和组分开指定,也可以同时指定:

  • 只指定所有者:chown newowner file
  • 只指定组:chown :newgroup file
  • 同时指定所有者和组:chown newowner:newgroup file

请注意,更改文件或目录的所有者和组通常需要超级用户权限(root权限),除非更改的对象是你自己拥有的文件或目录。

4. 例子

  1. 更改文件所有者

    chown user1 file.txt

file.txt 的所有者更改为 user1

  1. 更改所有者和组

    chown user1:group1 file.txt

同时更改文件的所有者为 user1,组为 group1

  1. 递归更改目录及其内容

    chown -R user1:group1 /path/to/directory

递归地更改目录和子文件的所有者及组。

相关推荐
羑悻的小杀马特2 分钟前
环境变量简介
linux
小陈phd35 分钟前
Vscode LinuxC++环境配置
linux·c++·vscode
运维&陈同学37 分钟前
【zookeeper01】消息队列与微服务之zookeeper工作原理
运维·分布式·微服务·zookeeper·云原生·架构·消息队列
是阿建吖!38 分钟前
【Linux】进程状态
linux·运维
hzyyyyyyyu1 小时前
内网安全隧道搭建-ngrok-frp-nps-sapp
服务器·网络·安全
明明跟你说过1 小时前
Linux中的【tcpdump】:深入介绍与实战使用
linux·运维·测试工具·tcpdump
Komorebi.py2 小时前
【Linux】-学习笔记05
linux·笔记·学习
Mr_Xuhhh2 小时前
重生之我在学环境变量
linux·运维·服务器·前端·chrome·算法
中云DDoS CC防护蔡蔡3 小时前
微信小程序被攻击怎么选择高防产品
服务器·网络安全·微信小程序·小程序·ddos