6.linux权限

一.本期指令速览

|-----------------|---------------------------------------------------------------------------------------------------------------|
| adduser/useradd | adduser:sudo adduser username useradd:sudo useradd username |
| groups(查看所属组) | 显示用户所属的用户组,它可以帮助了解当前用户或指定用户的组成员身份。 |
| chomd | 更改文件或目录权限的命令。 |
| sudo | 对指令进行提权 第一次sudo之后10~15分钟的登录期间不用再输密码; 默认情况下,普通账号是无法进行sudo的。(白名单) |
| chown | 更改文件或目录所有权的命令。基本语法如下: chown user1 example.txt chown user1:group1 example.txt |

1.adduser/useradd

adduser:

sudo adduser username

执行后会提示输入密码、全名等信息,并自动创建家目录(/home/username)。

useradd:

sudo useradd username

默认不会创建家目录,需通过 -m 选项显式启用

sudo useradd -m username

对于 useradd 创建的用户,需手动设置密码:

sudo passwd username

删除用户:

sudo deluser username # 保留家目录

sudo userdel -r username # 删除家目录

  • 若用户正在登录或进程占用文件,命令会报错并终止。
  • 需手动终止用户会话或进程后才能成功删除

userdel -rf 强制删除用户账户及相关文件(主目录、邮件池),忽略错误。(谨慎使用)

2.chmod

(1).数字模式

eg:chmod 755 filename

  • 7(4+2+1):所有者拥有读、写、执行权限。
  • 5(4+0+1):所属组和其他用户拥有读和执行权限。

(2).符号模式:

符号模式通过 u(所有者)、g(所属组)、o(其他用户)和**a(所有用户)** 来设置权限。操作符包括 +(添加权限)、-(移除权限)和 =(设置权限)。

eg:

(3).用户只能改变自己的文件权限

root.txt为root用户的文件

(4).没有权限系统会直接拒绝访问

root除外

3.chown(执行 chown 需要超级用户(root)权限或文件当前所有者的权限。)

修改文件 example.txt 的所有者为 user1:chown user1 example.txt

修改文件 example.txt 的所有者为 user1,组为 group1:chown user1:group1 example.txt

但是我们不能把文件给别人(更改想给别人必须要高权限--sudo或者su root)

二.知识点

1.sudo

不是说用了sudo就可以使用root的权限了,要首先 检查当前用户是否在/etc/sudoers文件中或被包含在sudo组中。使用groups命令查看用户所属组,确保包含sudo。(/etc/sudoers就类似于白名单)

2.

权限=角色+目标属性

eg:root是拥有者,root是所属组,除了拥有者和所属组就是other

读(r)、写(w)、执行(x)权限。

就比如张三和李四在赛马机制下做同一个项目,在处于竞争关系下肯定是最好不要让另一个人,看到自己的文件项目,但假如现在组长要想看张三的文件,如果没有所属组的话,张三就只能将权限放开(other),那么李四不也就可以看到张三的文件了吗?但如果有了所属组,张三只需要将组长拉到自己的所属组就可以单独看到张三的文件了。

3.

即带有w权限不是说文件就可以执行,通过gcc编译后才可以 ./文件名执行

文件名后每个角色所对应权限位置:

3.缺省权限

a.umask:用于控制新创建文件和目录默认权限的机制,,通过屏蔽(反向)权限位来定义新文件的初始权限。

umask 直接查看当前umask

实际权限 = 默认权限 & (~umask)

通过合理配置 umask,可以平衡系统安全性与用户便利性。

4.目录权限

  • 读(r) :允许查看目录内容(如ls命令)。
  • 写(w) :允许创建、删除或重命名目录内文件。
  • 执行(x) :允许进入目录 (如cd命令)或访问目录内文件的元数据。

所以说在默认情况下我们创建的目录都会有rwx权限

并且任何用户不能进入其他用户的家目录---实现了用户之间的隔离

确定权限时首先就对拥有者确定了权限所有只对拥有者开放了权限,对所属组和other都没有w权限,即都不能进入目录

相关推荐
小章UPUP2 小时前
自部署 LaTeX/Markdown 写作平台
linux
yunhuibin2 小时前
Linux 7.0 调度器:C 语言面向对象(OOPC)的极致实践
linux·运维·c语言
feng_you_ying_li2 小时前
linux之进程概念:体系结构,操作系统的基本介绍
linux
尘世壹俗人2 小时前
linux编译安装git
linux·运维·git
爱学习的小囧2 小时前
ESXi/vCenter 批量开关虚拟机完整教程 | PowerCLI 一键 + 原生脚本循环,新手也能落地
运维·网络·数据库·esxi
xxjj998a2 小时前
如何安装linux版本的node.js
linux·运维·node.js
AC赳赳老秦3 小时前
测试工程师:OpenClaw自动化测试脚本生成,批量执行测试用例
大数据·linux·人工智能·python·django·测试用例·openclaw
路溪非溪3 小时前
Wireshark抓取以太网MAC帧并进行分析
linux·网络·驱动开发·wireshark
一叶之秋14123 小时前
通信之道:解锁Linux进程间通信的无限可能(二)
linux·服务器