linux chmod命令和chown命令

简介:

一、chmod及文件权限

1、了解文件权限

root账户新建一个目录permission,在该目录新建一个文件file,通过ll就可以查看其权限。

复制代码
root@development:~# cd permission/
root@development:~/permission# touch file
root@development:~/permission# ls
file
root@development:~/permission# ll
total 8
drwxr-xr-x  2 root root 4096 Mar 19 00:33 ./
drwx------ 25 root root 4096 Mar 19 00:33 ../
-rw-r--r--  1 root root    0 Mar 19 00:33 file
root@development:~/permission# 
复制代码

可见一共有十位数,其中第一个-代表的是类型,比如./的类型是d就是目录。

从第二个开始,依次三个rw-代表的是所有者(user)拥有的权限。

再依次三个r--代表的是群组(group)拥有的权限。

最后三个r--代表的是其他人(other)拥有的权限

rwx-解释如下:

r:表示文件可以被读(read)

w:表示文件可以被写(write)

x:表示文件可以被执行,目录的话可以被搜索。

-:表示相应的权限还没有被授予

2、数字表示rwx

r ----------4

w ----------2

x ----------1

- ----------0

原理:将rwx看成是二进制的数,有用1表示,没有用0表示,那么rwx r-x r--就可以表示成:111 101 100,将其转换成为一个十进制数就是:754。

3、权限操作

+ 表示添加权限

- 表示删除权限

= 重置权限

4、常见权限

-rw------- (600) 只有所有者才有读和写的权限。

-rw-r--r-- (644) 只有所有者才有读和写的权限,群组和其他人只有读的权限。

-rw-rw-rw- (666)每个人都有读写的权限

-rwx------ (700) 只有所有者才有读,写和执行的权限。

-rwx--x--x (711) 只有所有者才有读,写和执行的权限,群组和其他人只有执行的权限。

-rwxr-xr-x  (755) 只有所有者才有读,写,执行的权限,群组和其他人只有读和执行的权限。

-rwxrwxrwx (777) 每个人都有读,写和执行的权限

5、目录相关的文件权限

如果有文件夹/a/b/c

查看权限

执行ls -l /a/b查看的并不是b的权限,而是c的权限。

  • ls -l /a查看的是b文件的权限
  • ls -l /a/b 查看的是c文件的权限
  • ls -l /a/b/c 查看的是c文件的权限

补充内容:知道这点很重要,举一个实际应用中的例子。

我曾在ssh登录时日志报错:/var/empty/sshd must be owned by root and not group or world-writable。

此时我就要看/var/empty/sshd的权限了。

用#ll /var/empty/sshd去查结果是total 0,代表里面没有文件。

而真正应该用的命令是#ll /var/empty,去查看它的上级目录。

然后就可以看到结果是:

total 0

drwxrwxrwx. 2 root root 6 May 13 03:41 sshd

修改权限和查看权限不同

  • chmod 700 /a 修改的是a文件的权限
  • chmod 700 /a/b 修改的是b文件的权限
  • chmod 700 /a/b/c修改的是c文件的权限。

补充内容:知道这点修改权限和查看权限不同也很重要,还是上面的例子。

我要修改/var/empty/sshd这个目录的权限,我需要用

#chmod 711 /var/empty/sshd去修改。

查看修改好的权限用#ll /var/empty查看。

6、修改文件权限

先举例:

# chmod o+w file:表示给其他人授予写file这个文件的权限

# chmod go-rw file:表示删除群组和其他人对file这个文件的读和写的权限

# chmod go-w+x mydir:拒绝组成员和其他人创建或删除mydir(go-w)中文件的权限,允许组成员和其他人搜索mydir,或在路径名(go+x)中使用它,等价于

chmod  g-w  mydir
chmod  o-w  mydir
chmod  g+x  mydir
chmod  o+x  mydir

解释:
u:代表文件所有者(user)

g:代表所有者所在的群组(group)

o:代表其他人,但不是u和g(other)

a:a和一起指定ugo效果一样

7、修改目录权限

如果要一次修改某个目录下所有文件的权限,包括子目录中的文件权限。需要使用-R参数。

# chmod 700 /srv/file #仅把file目录的权限设置为700
# chmod -R 744 /srv/file #将整个/srv/file目录和其子目录中所有文件权限设置为744

二、chowm和文件所有权

文件和目录权限可通过chomd来修改,文件和目录的所有权及所属用户组也可通过chown来修改。

root账户新建一个目录permission,在该目录新建一个文件file,通过ll就可以查看其权限。 

复制代码
[root@yl-web-test ~]# mkdir permission
[root@yl-web-test ~]# cd permission/
[root@yl-web-test permission]# ls
[root@yl-web-test permission]# touch file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 root root 0 Aug  6 09:17 file
复制代码

标红的root root表示file文件的所属用户组为root,所有者为root。

chown语法:

chown [选项]... [所有者][:[组]] 文件...

接下来简单介绍如何修改文件的所属用户组和所有者。

1、修改file文件的所有者为lxy

[root@yl-web-test permission]# chown lxy file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 lxy root 0 Aug  6 09:17 file

2、修改file文件的用户组为lxy

复制代码
[root@yl-web-test permission]# chown root file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 root root 0 Aug  6 09:17 file
[root@yl-web-test permission]# chown :lxy file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 root lxy 0 Aug  6 09:17 file
复制代码

3、同时修改文件的所有者和用户组

复制代码
[root@yl-web-test permission]# chown :root file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 root root 0 Aug  6 09:17 file
[root@yl-web-test permission]# chown lxy:lxy file
[root@yl-web-test permission]# ll
total 0
-rw-r--r--. 1 lxy lxy 0 Aug  6 09:17 file
复制代码

4、同时修改文件夹和其子文件的所属用户组和所有者,需要用-R参数。

假设file是一个目录,里面有一个a.txt的文件。它们的所有者和用户组如下,都是root:

复制代码
[root@yl-web-test permission]# cd file/
[root@yl-web-test file]# touch a.txt
[root@yl-web-test file]# ll
total 0
-rw-r--r--. 1 root root 0 Aug  6 09:40 a.txt
[root@yl-web-test file]# cd ..
[root@yl-web-test permission]# ll
total 0
drwxr-xr-x. 2 root root 18 Aug  6 09:40 file
复制代码

现将file目录和里面的a.txt文件的所有者和用户组都改为lxy,如下

复制代码
[root@yl-web-test permission]# chown -R lxy:lxy file
[root@yl-web-test permission]# ll
total 0
drwxr-xr-x. 2 lxy lxy 18 Aug  6 09:40 file
[root@yl-web-test permission]# cd file/
[root@yl-web-test file]# ll
total 0
-rw-r--r--. 1 lxy lxy 0 Aug  6 09:40 a.txt
复制代码

 

 

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4350212.html有问题欢迎与我讨论,共同进步。

相关文章
|
3月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
二、Linux文本处理与文件操作核心命令
|
3月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
317 137
|
3月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
724 57
|
6月前
|
JSON 自然语言处理 Linux
linux命令—tree
tree是一款强大的Linux命令行工具,用于以树状结构递归展示目录和文件,直观呈现层级关系。支持多种功能,如过滤、排序、权限显示及格式化输出等。安装方法因系统而异常用场景包括:基础用法(显示当前或指定目录结构)、核心参数应用(如层级控制-L、隐藏文件显示-a、完整路径输出-f)以及进阶操作(如磁盘空间分析--du、结合grep过滤内容、生成JSON格式列表-J等)。此外,还可生成网站目录结构图并导出为HTML文件。注意事项:使用Tab键补全路径避免错误;超大目录建议限制遍历层数;脚本中推荐禁用统计信息以优化性能。更多详情可查阅手册mantree。
553 143
linux命令—tree
|
2月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
491 2
|
3月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
324 0
Linux内存问题排查命令详解
|
3月前
|
Unix Linux 程序员
Linux文本搜索工具grep命令使用指南
以上就是对Linux环境下强大工具 `grep` 的基础到进阶功能介绍。它不仅能够执行简单文字查询任务还能够处理复杂文字处理任务,并且支持强大而灵活地正则表达规范来增加查询精度与效率。无论您是程序员、数据分析师还是系统管理员,在日常工作中熟练运用该命令都将极大提升您处理和分析数据效率。
305 16
|
5月前
|
监控 Linux 网络安全
Linux命令大全:从入门到精通
日常使用的linux命令整理
876 13
|
6月前
|
Linux 网络安全 数据安全/隐私保护
使用Linux系统的mount命令挂载远程服务器的文件夹。
如此一来,你就完成了一次从你的Linux发车站到远程服务器文件夹的有趣旅行。在这个技术之旅中,你既探索了新地方,也学到了如何桥接不同系统之间的距离。
1070 21
|
6月前
|
监控 Linux
Linux系统中使用df命令详解磁盘使用情况。
`df`命令是Linux系统管理员和用户监控和管理磁盘空间使用的重要工具。掌握它的基本使用方法和选项可以帮助在必要时分析和解决空间相关问题。简洁但功能丰富,`df`命令确保了用户可以快速有效地识别和管理文件系统的空间使用情况。
463 13