Linux:权限(完结)|权限管理|修改权限chmod chown charp|文件类型|拓展

上篇文章:

https://blog.csdn.net/2401_86123468/article/details/153525703?spm=1001.2014.3001.5501


回顾上篇文章结尾,以普通用户通过sudo提权为示例,但实际上,普通用户是无法进行sudo的,一般会遇到下面的情形:

那究竟要怎样才能直接执行呢?

实际上,在Linux中有一种白名单机制,只有在白名单(Linux中的一个配置文件)中的人,才能执行sudo(指令提权)。

那么是不是只要在白名单中的用户权限就可以和root一样了?

实际上,关于修改sudoers的权限,只有root可以修改。


1.权限管理

在Linux下,一切皆文件,实际权限管理就是"文件管理"。


对权限的解释:

权限的大小决定能不能完成一件事,在现实生活中,"人"是由"角色"和具体的人构成,那么,权限本质限制的也只是"角色"的不同。


在Linux系统中,权限角色有三类:文件的拥有者,文件的所属组,文件的other

在Linux系统中,任何文件,关于权限属性,一共有三类:r w x(可执行)

如上图所示,其中other是指除了拥有者和所属组之外的人,并不需要记录。

对比 拥有者,所属组,other 和 root xxx404......

其中,root......是指具体的人,也就是用户,而拥有者,所属组......是不同的角色,而具体的用户在不同的场景下会扮演不同的角色,拥有不用的权限。


在Linux中,文件不需要后缀,而是通过第一个字符确定,而其余的9个字符通过3个字符为一组,也有各自的含义:

**前三个字符对应拥有者的权限,中间三个字符对应所属组的权限,后三个字符对应other对应的权限。**完整权限示例:rwx--读、写、执行


**理解上述整体概念:**权限 = 角色 + 目标事物的属性

所属组的意义: 在大团体开发中,会有各类分组,组内的权限需要与其余组(other)相区别。总结为:在一个特定范围内,进行权限管理。

添加到组:

复制代码
# 创建项目组
sudo groupadd project

# 添加用户到项目组
sudo usermod -aG project xxx404

#查看
groups project

2.修改权限

1.chmod

**功能:**设置文件的访问权限

**格式:**chmod[参数] 权限 文件名


chmod命令权限值的格式:

用户表示符+/-=权限字符

+:向权限范围增加权限代号所表示的权限

-:向权限范围取消权限代号所表示的权限

=:向权限范围赋予权限代号所表示的权限

用户符号:

u:拥有者

g:拥有者同组用

o:其它用户

a:所有用户

示例:

拓展

**注意:****权限不能限制root:**当chmod u-rwx后,拥有者对文件什么操作都不能进行,但是root依旧可以读写执行。

问题一:

拥有者没有任何权限,但是我本身也是所属组,那么为什么我依旧没有读写的权限?

原因是,Linux中,身份匹配只会匹配一次。

问题三:

x可执行的含义,要怎么理解?

x指具有可执行权限 != 可以执行,可以执行 = 具有执行权限 + 二进制可执行文件


2.使用八进制修改权限

由于每个权限都是有或者无,那么就可以使用1或0代替有无。

复制代码
rwx -> 111
rw- -> 110
--- -> 000

区间范围:000 - 111,八进制为0 - 7

2.chown

**功能:**修改文件拥有者和所属组

**格式:**chown [参数] 用户名 文件名

3.charp

**功能:**修改文件或目录的所属组

**格式:**charp [参数] 用户组名 文件名

常用选项:-R 递归修改文件或目录的所属组

同时操作上述两个指令:

3.文件类型

在Linux中,第一个字符代表文件类型,之前讲过以下类型:

d:文件夹

-:普通文件

p:管道文件

c:字符设备文件(例如屏幕等串口设备)

S:套接口文件

今天新了解两种类型:

l:链接文件(类似Windows的快捷方式)

b:块设备文件(例如硬盘、光驱等)

对于块设备,以数据块为单位,支持随机读写,如磁盘,而不是按顺序读取,如键盘。

此处的vda,在Linux中指磁盘,而vda1就类似于windows电脑上的d盘,e盘......

本章完。

相关推荐
板鸭〈小号〉4 小时前
应用层自定义协议与序列化
运维·服务器·网络·1024程序员节
wanhengidc4 小时前
传奇手游可以使用云手机挂机搬砖吗
服务器·arm开发·智能手机·玩游戏·1024程序员节
报错小能手4 小时前
项目——基于C/S架构的预约系统平台(2)
linux·c语言·笔记·学习·架构
Wang's Blog5 小时前
Linux小课堂: CentOS 7 Minimal 服务器安装与网络配置实战详解
linux·服务器·centos
go_bai5 小时前
Linux_基础IO(2)
linux·开发语言·经验分享·笔记·学习方法·1024程序员节
Test-Sunny5 小时前
MLOps 的CI/CD VS DevOps 的CI/CD
运维·ci/cd·devops
华纳云IDC服务商5 小时前
服务器实时流量监控工具推荐:确保服务器不被滥用
服务器·流量监控
tritone5 小时前
在优豆云免费云服务器上搭建与配置Apache的实践笔记
服务器·网络·apache·1024程序员节
YongCheng_Liang5 小时前
Windows CMD 常用命令:7 大核心模块速查指南(附实战场景)
运维·服务器·windows·1024程序员节