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权限,即都不能进入目录

相关推荐
辞旧 lekkk2 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
腾讯蓝鲸智云2 小时前
【运维自动化-节点管理】节点管理的插件策略如何使用
运维·自动化·云计算·sass·paas
疯狂成瘾者4 小时前
服务器的单体和集群
运维·服务器
liuhuizuikeai5 小时前
可视化门禁---Linux/Qt+SqLite篇
linux·运维·qt
初願致夕霞5 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
charlie1145141918 小时前
嵌入式Linux驱动开发——新 API 字符设备驱动完整教程 - 从设备结构体到应用测试
linux·运维·驱动开发
飞Link8 小时前
2000 亿砸向算力:字节跳动 AI 基建跨越,后端与运维的“万亿 Token”生死战
运维·人工智能
消失的旧时光-19438 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
SWAGGY..8 小时前
Linux系统编程:(二)基础指令详解
linux·运维·服务器
kdxiaojie9 小时前
U-Boot分析【学习笔记】(3)
linux·笔记·学习