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盘......

本章完。

相关推荐
ZGi.ai13 小时前
用Agent编排实现合同审查自动化:完整实现过程
运维·人工智能·自动化
魔都吴所谓13 小时前
【Ubuntu】22.04安装 CMake 3.24
linux·运维·ubuntu
守城小轩13 小时前
基于Chrome140的INS账号自动化——需求分析&环境搭建(一)
运维·chrome devtools·浏览器自动化·指纹浏览器·浏览器开发
w61001046613 小时前
CKA-2026-resources
运维·docker·容器·cka
齐潇宇13 小时前
Rsync+sersync 实现数据实时同步故障排查
linux·自动化·rsync·排障·数据同步排障
程序员老邢13 小时前
【技术底稿 11】内网私有 Docker 镜像仓库 Registry2 全流程部署(多机共享,告别离线拷贝)
运维·docker·容器·架构·devops
86Eric13 小时前
基于 Rclone 实现 Linux 数据库备份自动同步至 Windows 本地
linux·windows·rclone 自动同步
楼田莉子14 小时前
设计模式:创建型设计模式简介
服务器·开发语言·c++·设计模式
SPC的存折14 小时前
6、MySQL设置TLS加密访问
linux·运维·服务器·数据库·mysql
wanhengidc14 小时前
云手机搬砖安全吗
大数据·运维·服务器·安全·游戏·智能手机