一起来学Linux命令(十)

简介: 一起来学Linux命令(十)

前言

目前正在出一个Linux命令系列教程, 篇幅会较多, 喜欢的话,给个关注❤️ ~

作为服务端开发,linux命令还是要掌握一下的,可以做做基础性的运维。好了, 废话不多说直接开整吧~

本节是该系列的最后一节,这节给大家介绍一些权限相关的命令,这些命令谨慎操作~

chmod

Linux系统中使用chmod命令时,可以修改文件或目录的权限。权限控制谁可以读取、写入和执行特定文件或目录。chmod命令允许更改这些权限,以便适应不同的安全需求

语法:

chmod [options] mode filename
  • options: 可选参数,用于指定一些特定选项,例如递归修改权限、静默模式等。
  • mode: 权限模式,可以是文字模式或数字模式。文字模式更容易理解,数字模式更为紧凑。
  • filename: 要修改权限的文件或目录名称。

权限模式

mode部分,可以使用以下字符来表示不同的权限:

  • u: 所有者(user)权限- g: 组权限- o: 其他用户权限- a: 所有用户权限(等同于ugo

每个权限部分可以使用以下字符来表示权限:

  • r: 读取权限- w: 写入权限- x: 执行权限

使用示例

  1. 使用文字模式设置权限
  • 设置所有者读、写、执行权限:chmod u=rwx filename
  • 设置组用户只读权限:chmod g=r filename
  • 设置其他用户执行权限:chmod o=x filename
  • 设置所有用户读权限:chmod a=r filename
  1. 使用数字模式设置权限
  • 设置所有者可读写执行,组和其他用户可读:chmod 744 filename
  • 所有者可读写执行,组可读执行,其他用户无权限:chmod 750 filename
  1. 递归修改目录及其内容的权限:如果要递归地修改目录及其内容的权限,可以使用-R选项。
  • 递归地给目录及其内容赋予所有者读写执行权限:chmod -R u=rwx directory
  1. 静默模式:使用-v选项可显示修改的文件。
  • 设置所有者可读写执行权限,并显示修改的文件:chmod -v u=rwx filename

chown

chown(change owner)命令用于更改文件或目录的所有者。在Linux系统中,每个文件和目录都有一个所有者,指定了谁有权访问和管理它。通过使用chown命令,可以将文件或目录的所有权转移给其他用户或组。

语法:

chown [options] new_owner: new_group filename
  • options: 可选参数,用于指定一些特定选项,如递归更改、保留设置等。
  • new_owner: 新的所有者的用户名或用户ID。
  • new_group: 新的组的组名或组ID。
  • filename: 要更改所有者和/或组的文件或目录名称。

使用示例

  1. 更改所有者

  - 将文件的所有者更改为新用户:chown newuser filename   - 将目录的所有者更改为新用户:chown newuser directory

  1. 更改组

  - 将文件的组更改为新组:chown :newgroup filename   - 将目录的组更改为新组:chown :newgroup directory

  1. 同时更改所有者和组

  - 将文件的所有者和组同时更改:chown newuser:newgroup filename   - 将目录的所有者和组同时更改:chown newuser:newgroup directory

  1. 递归更改目录及其内容的所有者和组

  如果要递归地更改目录及其内容的所有者和组,可以使用-R选项。

  - 递归地将目录及其内容的所有者和组都更改为新用户和新组:chown -R newuser:newgroup directory

  1. 保留文件的组,只更改所有者

  使用-c选项来仅在所有者或组发生变化时显示修改的文件。

  - 仅更改文件的所有者,保留组:chown -c newuser filename

这些示例展示了如何使用chown命令来更改文件和目录的所有者和组。在实际使用时,请确保具有足够的权限来更改所有者和组。更改所有者和组可能会影响文件的访问和权限设置,因此务必小心操作。

chgrp

语法:

chgrp [options] new_group filename
  • options: 可选参数,用于指定一些特定选项,如递归更改等。
  • new_group: 新的组的组名或组ID。
  • filename: 要更改所属组的文件或目录名称。

使用示例

  1. 更改组

  - 将文件的组更改为新组:chgrp newgroup filename   - 将目录的组更改为新组:chgrp newgroup directory

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

  如果要递归地更改目录及其内容的组,可以使用-R选项。

  - 递归地将目录及其内容的组都更改为新组:chgrp -R newgroup directory

  1. 保留所有者,只更改组

  使用-c选项来仅在组发生变化时显示修改的文件。

  - 仅更改文件的组,保留所有者:chgrp -c newgroup filename

umask

umask 是一个重要的系统命令,用于设置新文件和目录默认权限的掩码。在Linux和类Unix操作系统中,每个文件和目录都有一组权限位,用于控制谁可以访问文件或目录以及在何种方式下可以访问。umask 通过掩码的方式影响这些权限,用于限制默认的权限。

语法:

umask [options] [mode]
  • options: 可选参数,用于指定一些特定选项,例如显示当前 umask 值。
  • mode: 可选参数,用于设置新的 umask 值。mode 通常由三位数字表示,如 022。这三位数字分别表示文件权限的 rwx 位,其中每一位的值分别为 r(读取权限),w(写入权限),x(执行权限)。

作用

umask 的作用是屏蔽掉新创建文件和目录的默认权限位。更具体地说,umask 的值会从新文件或目录的默认权限中减去,以确定它们的最终权限。这是通过按位取反 umask 值然后与默认权限进行按位与操作来实现的。例如,如果 umask 设置为 022,则新文件的默认权限会被修改为 rw-r--r--(所有者可读写,其他用户只可读)。

示例

  1. 查看当前 umask

要查看当前系统的 umask 值,只需运行 umask 命令,它将返回当前的 umask 值:

umask
  1. 设置新的 umask

要设置新的 umask 值,只需将所需的权限位值传递给 umask 命令。例如,要将 umask 设置为 027

umask 027
  1. 永久修改 umask

若要永久修改 umask 值,可以在用户的 shell 配置文件中添加 umask 命令。例如,将 umask 设置为 027 并永久保存:

~/.bashrc~/.bash_profile 文件中添加以下行:

umask 027   

这将确保在每次用户登录时都会应用指定的 umask 值。

注意事项

  • umask 的值通常以八进制表示,因此请确保使用正确的格式来设置它。
  • umask 设置的值影响新文件和目录的默认权限,但不会影响已经存在的文件和目录的权限。
  • 默认的 umask 值通常设置为 022002,这样新文件会具有相对安全的默认权限,但可以根据需求进行调整。
  • 注意,在设置 umask 值时,要确保不要过于放宽文件和目录的默认权限,以保护系统的安全性。

su

su(switch user)是一个在Unix和类Unix操作系统中用于切换用户的命令。它允许已登录的用户切换到另一个用户账户,通常是超级用户(root),以便执行需要特殊权限的任务。

语法:

su [options] [username]
  • options:可选参数,用于指定一些特定选项,例如保持环境变量、使用登录 shell 等。
  • username:可选参数,要切换到的目标用户账户。如果未提供该参数,默认会切换到超级用户账户(root)。

示例

  1. 切换到超级用户(root)

如果不提供任何用户名,su 命令会默认将用户切换到超级用户(root):

su 

需要输入超级用户的密码才能切换到 root 用户。

  1. 切换到其他用户

要切换到特定的用户账户,只需将目标用户名作为参数传递给 su 命令:

su username

在这里,将 username 替换为要切换到的实际用户名。

  1. 保持环境变量

默认情况下,使用 su 命令切换到其他用户时,环境变量会被重置为目标用户的默认值。如果希望保留当前用户的环境变量,可以使用 - 选项:

su - username   

或者可以使用 --login 选项,效果相同:

su --login username
  1. 使用登录 shell

使用 -l 选项,也可以使用 --login 选项,可以强制切换到目标用户的登录 shell:

su -l username   

注意事项

  • 当切换到其他用户账户时,需要输入目标用户的密码,除非是超级用户(root)。
  • 使用 su 命令时,请小心不要意外地执行系统中的敏感操作,尤其是当切换到超级用户时。因为超级用户具有系统的最高权限,可以对系统进行任何更改。
  • 请谨慎使用超级用户(root)权限,仅在必要时切换到超级用户账户来执行需要特殊权限的任务。
  • 在许多系统中,为了安全起见,su 命令可能需要在特定的用户组中或具有特定权限的用户才能使用。

chown

chown 是一个用于更改文件或目录的所有者(owner)和所属组(group)的命令。在Unix和类Unix操作系统中,每个文件和目录都有一个所有者和一个所属组,这些属性决定了谁可以访问文件以及如何访问。chown 命令允许系统管理员或文件所有者更改这些属性,以便更好地管理文件系统。

语法:

chown [options] owner[:group] file(s)
  • options:可选参数,用于指定一些特定选项,例如递归操作、改变文件类型等。
  • owner:新的所有者的用户名或用户ID。
  • group:可选参数,新的所属组的组名或组ID。如果省略,将保持原始所属组不变。
  • file(s):要更改所有者和/或所属组的文件或目录。

示例

  1. 更改文件所有者

要更改文件的所有者,只需提供新的用户名或用户ID,以及要更改的文件的路径:

chown newuser file.txt  
  1. 更改文件的所有者和所属组

要同时更改文件的所有者和所属组,可以在 owner 后面加上 :,然后指定新的组名或组ID:

chown newuser:newgroup file.txt
  1. 只更改所属组

如果只想更改文件的所属组,而不改变所有者,可以使用 :,但省略 owner

chown :newgroup file.txt  
  1. 递归更改目录及其内容

使用 -R 选项可以递归地更改目录及其所有内容的所有者和/或所属组:

chown -R newuser:newgroup directory/

注意事项

  • 在使用 chown 命令时,确保提供正确的用户名、用户ID、组名或组ID。否则,可能会导致文件所有权混乱,甚至可能导致访问问题。
  • 使用 chown 命令需要足够的权限。通常,只有文件的所有者或超级用户(root)可以更改所有者和所属组。
  • 谨慎使用 chown 命令,特别是在系统范围内递归更改所有者和所属组。不正确的使用可能会影响系统的正常运行和安全性。
  • 如果是普通用户,可能需要超级用户权限(通过 sudo 命令)来执行某些 chown 操作。
  • 在执行递归操作时,请特别小心。确认要更改的文件和目录,以及更改后的所有者和所属组。

结束语

本系列就到此为止了,这些命令不用全记住 用到的时候想不起来查一下就好,其实用多了 自然而然就记住了~

本着把自己知道的都告诉大家,如果本文对有所帮助,点赞+关注鼓励一下呗~

相关文章
|
2月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
252 8
|
2月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
977 6
|
2月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
150 3
|
2月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
125 2
|
1月前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
84 14
Linux 10 个“who”命令示例
|
1月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
166 20
|
28天前
|
Linux
linux查看目录下的文件夹命令,find查找某个目录,但是不包括这个目录本身?
通过本文的介绍,您应该对如何在 Linux 系统中查看目录下的文件夹以及使用 `find` 命令查找特定目录内容并排除该目录本身有了清晰的理解。掌握这些命令和技巧,可以大大提高日常文件管理和查找操作的效率。 在实际应用中,灵活使用这些命令和参数,可以帮助您快速定位和管理文件和目录,满足各种复杂的文件系统操作需求。
81 8
|
1月前
|
网络协议 Linux 应用服务中间件
kali的常用命令汇总Linux
kali的常用命令汇总linux
80 7
|
2月前
|
Linux 数据库
Linux中第一次使用locate命令报错?????
在Linux CentOS7系统中,使用`locate`命令时出现“command not found”错误,原因是缺少`mlocate`包。解决方法是通过`yum install mlocate -y`或`apt-get install mlocate`安装该包,并执行`updatedb`更新数据库以解决后续的“can not stat”错误。
53 9
|
2月前
|
监控 网络协议 Linux
Linux netstat 命令详解
Linux netstat 命令详解