Linux下基本指令(4)

Linux权限的概念

Linux下有两种用户:超级用户(root)、普通用户。

超级用户:可以再linux系统下做任何事情,不受限制

普通用户:在linux下做有限的事情。

超级用户的命令提示符是“#”,普通用户的命令提示符是“$”。

命令:su [用户名]

功能:切换用户。

例如,要从root用户切换到普通用户user,则使用 su user。 要从普通用户user切换到root用户则使用 su root(root可以省略),此时系统会提示输入root用户的口令。如果

是在普通用户下,切换到root用户,家目录还是普通用户的家目录,只是身份转变了。要退回普通用户,输入exit指令或者是ctrl + d热键。

如果使用su -则直接重新登录root用户,此时的家目录也是root。

在root用户下变成其它用户:

暂时的对一条命令进行提权sudo command:

目前用adduser新建的用户,没有办法执行sudo ,系统不信任你,除非未来将普通用户添加到系统信任的白名单里。

什么叫做权限?权限就是什么事情允许被你做。1.权限认证的是身份(权限和“人”有关),身份权限认证的时候,其实认证的就是人和身份是否吻合。2.权限也和事物的属性有关。

文件属性:

Feb 17 17:24 是文件最近修改或者创建的时间。 d和-是文件的类型,文件的类型在Windows当中是通过文件名后缀来区分的,在Linux系统中文件名后缀没有直接的意义。

-:普通文件(文本文件、源代码,还有库文件、可执行程序在Linux上都是普通文件)

d:目录文件

b:块设备文件(跟硬件有关系),最典型的块设备文件一般在计算机里都叫做磁盘,一般的磁盘文件我们都叫做块设备文件

因为Linux下一切皆文件, /dev/vdal就是在服务器上用的那个磁盘,当然这个磁盘是虚拟出来的。磁盘在读取时是整块进行读取的。 

c:字符设备文件,在Linux下通常指的是字符设备,这些字符是被最常见的像键盘,显示器文件等。

显示器设备一般叫做/dev/tty。

当前这里一共有这么多的显示器文件(未全包含):

这些显示器文件tty就是终端的意思, 为什么键盘、显示器叫做字符设备呢?因为这些文件在进行数据的输入输出时,它是按照字符为单位,一个个的喂给内存当中的进程或者程序的。

p:管道文件,是用来通信的。

文件的属性主要是对目录文件和普通文件来说的。

r:表示可读

w:表示可写

x:表示可执行

-:对应的权限位置,什么都没有,换句话说也就是什么都没有

这里的“人”不是代表一个用户,是代表一个角色,权限身份,Linux中将角色划分为三种,一种是文件对应的拥有者(代表这个文件是谁的),第三种叫做文件对应的其他人(代表这个文件不属于谁),中间的叫做文件对应的所属组(代表的是比如六个用户是属于同一个组的,他们可以给特定的目录或者文件设定一些组级别的约束,就可以保证组内的一些人共享某些资源)。、

那root用户以及普通用户和拥有者、所属者、其他人有什么关系呢?

其实root用户可以由拥有者、所属者、其他人扮演,普通用户可以由拥有者、所属者、其他人扮演,拥有者、所属者、其他人相当于角色或者身份,而root和普通用户相当于具体的某些人。比如说校长是一个身份,张三是一个人。

第一个liusiwei叫做该文件的拥有者,也就是empty这个文件的拥有者是liusiwei这个用户,第二个liusiwei代表文件的所属组。drwxrwxr-x第一列代表文件类型,剩下的叫做文件的权限属性,2、1、1先不讲,到时候讲到文件系统再说。4096代表的是文件的大小,单位是字节,Feb 17 17:24 代表文件最近的修改或者创建时间,最后是文件名。

那其他人呢?

当我用root账户登陆时,我要访问一个文件,那这个文件的所属组还有拥有者是root吗,如果不是,root就是其他人,这个时候就有了其他人了。

去掉第一列的一个字符,剩下的从左向右3、3为一组,第一组是文件的属性,这个属性和拥有者结合,它代表的就是拥有者权限,第二组是所属组的权限,它就和所属组相关联,第三组和其他人对应,叫做其他人权限。

去掉一个文件的所有人的所有权限:

root用户不受权限约束:

增加一个人的权限:

也可以用二进制来修改权限:

把文件给另一个用户(要在root账户下使用):

把所属组权限给另一个用户(需要在root账户下使用):

把拥有者、所属组权限还给自己(需要在root账户下使用): 

创建三个文件: 

 为什么我们创建文件的默认权限是我们所看到的样子?

为什么普通文件的默认权限是664?

为什么目录文件的默认权限是775?

1.在Linux当中,默认给普通文件起始权限其实是666,2.默认给目录文件的起始权限其实是777,但为什么是我们图中所见到的样子的呢?根本原因在于我们的Linux当中存在一个umask的东西,叫做权限掩码。权限掩码:凡是在umask中出现的权限,不会在最终的文件权限中出现。

最终权限 = 起始权限 & (~umask)。

Linux权限管理

01.文件访问者的分类(人)

文件和文件目录的拥有者:u

文件和文件目录的所属组:g

其他人:o

02.文件类型和访问权限(事物属性)

 a) 文件类型

d:文件夹

-:普通文件

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

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

p:管道文件

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

s:套接口文件

这里只需要记住d和-,其它的后面遇到的话再详谈。

b)基本权限

i.读(r/4):Read对文件而言,具有读取文件内容的权限;对目录来说,具有浏览该目录信息的权限

ii.写(w/2):Write对文件而言,具有修改文件内容的权限;对目录来说具有删除移动目录内文件的权限

iii.执行(x/1):execute对文件而言,具有执行文件的权限;对目录来说,具有进入目录的权限

iv.“—”表示不具有该项权限

03.文件权限值的表示方法

a)字符表示方法

b)8进制数值表示方法

04.文件访问权限的相关设置方法

a)chmod

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

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

常用选项:R -> 递归修改目录文件的权限

说明:只有文件的拥有者和root才可以改变文件的权限

chmod命令权限值的格式

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

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

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

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

用户符号:  

u:拥有者

g:拥有者同组用

o:其它用户

a:所有用户

chmod a=x /home/abc.txt

②三位8进制数字

b)chown

功能:修改文件的拥有者

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

 c)chgrp

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

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

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

chgrp users /abc/f2

d)umask

功能: 查看或修改文件掩码

新建文件夹默认权限=0666

新建目录默认权限=0777

但实际上你所创建的文件和目录,看到的权限往往不是上面这个值。原因就是创建文件或目录的时候还要受到 umask的影响。假设默认权限是mask,则实际创建的出来的文件权限是: mask & ~umask

格式:umask 权限值

说明:将现有的存取权限减去权限掩码后,即可产生建立文件时预设权限。超级用户默认掩码值为0022,普通用户默认为0002。

修改权限掩码:

 

file指令:

功能说明:辨识文件类型。

语法:file [选项] 文件或目录... 

常用选项: -c 详细显示指令执行过程,便于排错或分析程序执行的情形。

-z 尝试去解读压缩文件的内容

使用 sudo分配权限

(1)修改/etc/sudoers 文件分配文件

格式:接受权限的用户登陆的主机 =(执行命令的用户) 命令

(2)使用 sudo 调用授权的命令

$ sudo –u 用户名 命令

目录的权限

可执行权限:如果目录没有可执行权限,则无法cd到目录中

可读权限:如果目录没有可读权限,则无法用ls等命令查看目录中的文件内容

可写权限:如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件

于是,问题来了~~

如果目录没换句话来讲,就是只要用户具有目录的写权限,用户就可以删除目录中的文件,而不论这个用户是否有这个文件的写权限.。这好像不太科学啊,我张三创建的一个文件,凭什么被你李四可以删掉? 我们用下面的过程印证一下有可写权限,则无法在目录中创建文件,也无法在目录中删除文件。

 为了解决这个不科学的问题, Linux引入了粘滞位的概。

粘滞位

当一个目录被设置为"粘滞位"(用chmod +t),则该目录下的文件只能由

一、超级管理员删除

二、该目录的所有者删除

三、该文件的所有者删除 

关于权限的总结

目录的可执行权限是表示你可否在目录下执行命令。

如果目录没有-x权限,则无法对目录执行任何命令,甚至无法cd 进入目, 即使目录仍然有-r 读权限(这 个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件)。

而如果目录具有-x权限,但没有-r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限。

所以在目录下,即使可以执行ls命令,但仍然没有权限读出目录下的文档。

建立和删除带-的文件:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/973895.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络安全设备防护原理 网络安全防护装置

🍅 点击文末小卡片 ,免费获取网络安全全套资料,资料在手,涨薪更快 防火墙 简介 网络层的防护设备,依照特殊的规则允许或者限制传输的数据通过 是由软件和硬件设备组合而成,在内部网和外部网之间、专用网…

windwos与linux环境下Iperf3带宽测试工具的安装、使用

目录 一、前言 二、windows 2.1下载 2.2安装 2.3使用 2.3.1服务端 2.3.2客户端 2.3.3输出内容 1.客户端 2.服务端 2.4.相关命令 三、linux 3.1安装 3.2使用 1.服务端 2.客户端 3.输出内容 1.客户端 2.服务端 一、前言 在数字化浪潮下,网络性能…

达梦统计信息

统计信息 统计信息概述 统计信息是数据库中关于表和索引数据的元信息,用于描述数据的分布、唯一性、大小等特征。数据库优化器依赖统计信息来选择最优的执行计划。统计信息对于 CBO(基于代价的优化器)生成执行计划具有直接影响。 收集统计…

【面试系列】Java开发--AI常见面试题

1、实际工作或学习中用过哪些Ai工具 1.1、AI编程1.2、AI对话聊天1.3、AI图像工具1.4、AI办公工具 2、谈谈你知道的AI领域的一些常见词汇及其含义的理解? 例如AIGC、LLM、DeepLearning分别是什么意思? 2.1、AIGC(Artificial Intelligence Gene…

一文讲解Redis为什么读写性能高以及I/O复用相关知识点

Redis为什么读写性能高呢? Redis 的速度⾮常快,单机的 Redis 就可以⽀撑每秒十几万的并发,性能是 MySQL 的⼏⼗倍。原因主要有⼏点: ①、基于内存的数据存储,Redis 将数据存储在内存当中,使得数据的读写操…

OnlyOffice:前端编辑器与后端API实现高效办公

OnlyOffice:前端编辑器与后端API实现高效办公 一、OnlyOffice概述二、前端编辑器:高效、灵活且易用1. 完善的编辑功能2. 实时协作支持3. 自动保存与版本管理4. 高度自定义的界面 三、后端API:管理文档、用户与权限1. 轻松集成与定制2. 实时协…

【opencv】图像基本操作

一.计算机眼中的图像 1.1 图像读取 cv2.IMREAD_COLOR:彩色图像 cv2.IMREAD_GRAYSCCALE:灰色图像 ①导包 import cv2 # opencv读取的格式是BGR import matplotlib.pyplot as plt import numpy as np %matplotlib inline ②读取图像 img cv2.imread(…

fastadmin实现海报批量生成、邮件批量发送

记录一个海报批量生成、邮件批量发送功能开发,业务场景如下: 国外客户做观展预登记,工作人员通过后台,批量给这些观众生成入场证件并发送到观众登记的邮箱,以方便观众入场时快速进场。证件信息包含入场二维码、姓名&a…

3.Docker常用命令

1.Docker启动类命令 1.启动Docker systemctl start docker 2.停止Docker systemctl stop docker 3.重启Docker systemctl restart docker 4.查看Docker状态 systemctl status docker 5.设置开机自启(执行此命令后每次Linux重启后将自启动Docker) systemctl enable do…

1.21作业

1 unserialize3 当序列化字符串中属性个数大于实际属性个数时,不会执行反序列化 外部如果是unserialize()会调用wakeup()方法,输出“bad request”——构造url绕过wakeup 类型:public class&…

【Spring详解四】自定义标签的解析

四、自定义标签的解析 自定义标签的解析是通过 BeanDefinitionParserDelegate .parseCustomElement(ele)进行的,解析来我们进行详细分析。 DefaultBeanDefinitionDocumentReader.class 4.1 自定义标签的使用 扩展 Spring 自定义标签配置一般需要以下几个步骤&#x…

基于springboot校园健康系统的设计与实现(源码+文档)

大家好我是风歌,今天要和大家聊的是一款基于springboot的园健康系统的设计与实现。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 基于springboot校园健康系统的设计与实现的主要使用者管理员具有最高的权限,通…

如何修改Windows系统Ollama模型存储位置

默认情况下,Ollama 模型会存储在 C 盘用户目录下的 .ollama/models 文件夹中,这会占用大量 C 盘空间,增加C盘“爆红”的几率。所以,我们就需要修改Ollama的模型存储位置 Ollama提供了一个环境变量参数可以修改Ollama的默认存在位…

基于Python+Vue开发的反诈视频宣传管理系统源代码

项目简介 该项目是基于PythonVue开发的反诈视频宣传管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Python编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Python的反…

VMware安装Centos 9虚拟机+设置共享文件夹+远程登录

一、安装背景 工作需要安装一台CentOS-Stream-9的机器环境,所以一开始的安装准备工作有: vmware版本:VMware Workstation 16 镜像版本:CentOS-Stream-9-latest-x86_64-dvd1.iso (kernel-5.14.0) …

华为云deepseek大模型平台:deepseek满血版

华为云硅基流动使用Chatbox接入DeepSeek-R1满血版671B 1、注册: 华为云deepseek大模型平台注册:https://cloud.siliconflow.cn/i/aDmz6aVN 说明:填写邀请码的话邀请和被邀请的账号都会获得2000 万 Tokens;2个帐号间不会与其他关联…

import requests Pycharm 报错

#PyCharm安装requests失败解决方法 PyCharm安装request失败解决方法(亲测有效) import requests Pycharm 报错 尝试从系统终端运行此命令。确保使用为 D:\Python\venv\Scripts\python.exe 处的 Python 解释器安装的正确版本的 pip。失败一&#xff1…

基于云的物联网系统用于实时有害藻华监测:通过MQTT和REST API无缝集成ThingsBoard

论文标题 **英文标题:**Cloud-Based IoT System for Real-Time Harmful Algal Bloom Monitoring: Seamless ThingsBoard Integration via MQTT and REST API **中文标题:**基于云的物联网系统用于实时有害藻华监测:通过MQTT和REST API无缝集…

VMware converter standalone迁移windows老版本系统到esxi

最近因为有个客户有5台老服务器想淘汰掉换成新服务器,有多老呢?差不多20年了。比我干这个行业的时间还久。 老服务器的系统分别是: 1:3台windows server 2008 sp2 x64系统 2:2台windows server 2003 sp2 x32系统 新服务…

python学opencv|读取图像(七十五)人脸识别:Fisherfaces算法和LBPH算法

【1】引言 前序学习进程中,已经掌握了使用Eigenfaces算法进行的人脸识别。相关文章链接为: python学opencv|读取图像(七十四)人脸识别:EigenFaces算法-CSDN博客 在此基础上,学习剩余两种人脸识别算法&am…