Linux 文件权限
优质博文:IT-BLOG-CN
一、使用者与群组的概念
【1】在Linux
里面,任何一个文件都具有[User,Group及Other]
三种身份的个别权限:不过需要注意的是root用户,具有所有权限。
✔ User
(文件拥有者):只有文件拥有者,就是你自己,才能看与修改这个文件的内容;
✔ Group
(群组的概念):群组是最有用的功能之一,就是当你在团队开发资源的时候,会进行团队内共享;
✔ Other
:剩余的都是其他人;
【2】Linux
用户身份与群组记录文件:在Linux
系统中,所有的账号与一般身份使用者,还有root
的相关信息,都是记录在/etc/passwd
这个文件内。至于个人密码则是记录在/etc/shadow
文件。Linux
所有的组名都记录在/etc/group
内。
二、Linux 文件权限概念
注意: 当出现【Permission deny】
的时候肯定是权限设定错误。
【1】通过『ls』
指令查看文件,当使用的非root
用户,建议切换至root
用户『su -』
因为后续chgrp
、chown
等指令可能都需要使用root
身份才能处理,离开则使用『exit』
回到非root
身份。通过『ls -al』
(包含隐藏文件,文件名第一个字符为『.』
的文件)得到如下信息:
[root@learnVM ~]# ls -al
总用量 248
drwxr-xr-x. 2 root root 4096 7月 19 21:00 .abrt
-rw-------. 1 root root 1377 7月 19 20:44 anaconda-ks.cfg
drwxr-xr-x. 2 root root 4096 7月 24 01:36 .oracle_jre_usage <=范例说明
[ 权限 ] [连结] [拥有者] [群组] [文件容量] [ 修改日期 ] [ 档名 ]
【2】第一栏代表这个文件的类型与权限permission
:
● 第一个字符代表这个文件是『目录、文件或链接文件等等』:
○ 当为[ d ]
则是目录
○ 当为[ - ]
则是文件
○ 若为[ I ]
则表示为连接档Iink file
○ 当为[ b ]
则表示为装置文件里面的可供存储的接口设备(可随机存取装置)
○ 当为[ c ]
则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)
● 接下来的字符三个为一组,如上图所示。这三个权限的位置不会改变,如果没有权限就会出现减号[ - ]
。
【3】第五栏为这个文件的容量大小,默认单位为bytes
。
【4】例题:drwxr-xr-- 1 test testgroup 5238 Jun 19 10:25 groups/
分析如下:
◐ 文件拥有这test[rwx]
可以在本目录中进行任何工作;
◐ 而testgroup
这个群组[r-x]
的账号,例如test1
亦可进入本目录工作,但是不能在本目录下进行写入的动作。
◐ 至于other
的权限[r--]
,虽然有r
,但是由于没有x
权限,因此others
的使用者,并不能进入此目录。
三、Linux文件权限的重要性
在Linux
系统当中,每一个文件都加了很多属性进来,尤其是群组的概念,其最大的用途就是在『数据安全性』上面。
◑ 系统保护的功能: 例如在系统中,关于系统服务的文件通常只有root
才能读写或者是执行,例如/etc/shadow
这一个账号管理的文件,由于该文件记录了系统中所有账号数据,当然不能让任何人读取,否则密码会被盗取。只有root
才能够读取。So
,该文件的权限为[----------]
所有人都不能使用,root用户基本上是不受系统的权限所限制的。
◑ 团队开发软件或数据共享的功能: 例如在团队中,希望每个人都可以使用某些目录下的文件,而非团队的其他人则不予以开发,可以将权限设置为[-rwxrws---]
来提供给团队使用。
◑ 未将权限设定妥当的危害: 如果目录权限未设置好,会造成其他人都可以对文件进行操作。导致一些莫名奇妙的问题。
四、如何改变文件属性与权限
我们现在知道文件权限对于一个系统的安全性,也知道文件的权限对于使用者于群组的相关性,其实一个文件的属性和权限有很多,我们先介绍几个常用于群组、拥有者、各种身份的权限之修改的指令,如下所示:
● chgrp
:改变文件所属群组;
● chown
:改变文件拥有者;
● chmod
:改变文件的权限,SUID
,SGID
,SBIT
等等特性;
【1】改变所属群组(chgrp
:change group
的缩写):需要注意的是,要被改变的组名必须要走/etc/group
文件中存在才行,否则就会显示错误。如下使用 root
身份将a
文件移至zzx
(存在于/etc/group
群组)群组和zzx1
(不存在于/etc/group
群组)群组,此时会出现如下现象:
[root@learnVM install]# chgrp [-R] dirname/filename ...
/*选项与参数:-R:进行递归(recursive)的持续变更,亦既连同次目录下的所有文件、目录都更新称为这个群组之意。
常用在变更某一目录内所有文件的时候使用。*/
//范例:
[root@learnVM install]# chgrp zzx a
[root@learnVM install]# ll
-rw-r--r--. 1 root zzx 3 12月 25 00:13 a
[root@learnVM install]# chgrp zzx1 a
chgrp: 无效的组:"zzx1" //<= 发生错误讯息
【2】改变拥有者(chown
:change owner
的缩写):需要注意的是,用户必须是存在于系统中的账号,也就是/etc/passwd
这个文件中有记录的用户名称才能改变。chown
也可以直接修改群组的名称。此外,如果要连目录下的所有次目录或文件同时更改拥有者的话,直接加上-R
的选项即可。
[root@learnVM install]# chown [-R] 账号名称 文件或目录
[root@learnVM install]# chown [-R] 账号名称:组名 文件或目录
选项与参数
-R:进行递归(recursive)的持续变更,亦既连同次目录下的文件都变更范例:将a 的拥有者改为zzx
[root@learnVM install]# ll
-rw-r--r--. 1 root zzx 3 12月 25 00:13 a
[root@learnVM install]# chown zzx a
[root@learnVM install]# ll
-rw-r--r--. 1 zzx zzx 3 12月 25 00:13 a范例:将a 的拥有者和群组改回root,也可以将:更换成.如果之修改群组也可以,如下:.root
[root@learnVM install]# chown root:root a
[root@learnVM install]# ll
-rw-r--r--. 1 root root 3 12月 25 00:13 a
【3】改变权限(chmod
): 文件权限的设定方式有两种,分别是数字或者符号来进行权限的变更。
- 数字类型改变文件权限:
1)Linux
文件的基本权限就有九个,分别是owner/group/others
三种身份各有自己的read/write/execute
权限。其中,我们可以通过数字来代表各个权限,各个权限分数对照如下:
r:4w:2x:1
2)每种身份(owner/group/others)
各自的三个权限(r/w/x)
分数是需要累加的,例如当权限为:[-rwxrwx---]
分数则是:
owner = rwx = 4+2+1 = 7group = rwx = 4+2+1 = 7other = --- = 0+0+0 = 0
3)所以等下我们设定权限的变更时,该文件的权限数据就是770
了。变更权限的指令如下:
[root@learnVM install]# chomd [-R] xyz 文件或目录
/*选项与参数:xyz:就是刚刚提高的数字类型的权限属性,为rwx属性值的相加
-R:进行递归(recursive)的持续变更,亦既连同次目录下的所有文件都会变更*/
范例:将a的权限设置为[-rwxrwx---]
[root@learnVM install]# ll
-rw-r--r--. 1 root root 3 12月 25 00:13 a
[root@learnVM install]# chmod 770 a
[root@learnVM install]# ll
-rwxrwx---. 1 root root 3 12月 25 00:13 a
- 符号类型改变文件权限【了解,基本不用】
1)从上面介绍中可以发现,基本上就是九个权限分别是user
、group
、others
三种身份,我们可以由u
,g
,o
来代表三种身份的权限。此外,a
则代表all
全部的身份,那么读取权限就可以写成r
,w
,x
。
chmod | u / g / o /a | +(加入) / -(除去) / =(设定) | r / w / x | 文件或目录 |
---|
2)实际操作,设置文件的权限为『-rwxr-xr-x』
解读后就是:user(u)
:具有所有权限,group
与others(g/o)
:具有读/可执行权限。
[root@learnVM install]# chmod u=rwx,og=rx a
// 注意:那个u=rwx,og=rx 是连在一起的,中间没有任何空格
[root@learnVM install]# ll
-rwxr-xr-x. 1 root root 3 12月 25 00:13 a
// 当给所有的角色添加w权限(+的使用)
[root@learnVM install]# chmod a+w a
[root@learnVM install]# ll
-rwxrwxrwx. 1 root root 3 12月 25 00:13 a
// 当给所有的角色出去x权限(-的使用)
root@learnVM install]# chmod a-x a
[root@learnVM install]# ll
-rw-rw-rw-. 1 root root 3 12月 25 00:13 a
五、目录与文件权限意义
【1】文件是实际含有数据的地方,包括一般文本文件、数据库内容文件、二进制可执行文件(binary program)
等等。其中『x』
的意义我们可以解释一下:在Windows
底下一个文件是否具有执行的能力是基于『扩展名』来判断的,如:.exe,.bat,.com
等等,但是在Linux
底下,我们的文件是否可执行,则是基于是否具有『x』
这个权限来决定的! 跟文档名没有绝对的关系。
一个文件具有『w』
权限时,你可以具有写入/编辑/新增/修改文件内容的权限,但不具备删除该文件本身的权限,对于文件的rwx
来说,主要都是针对『文件的内容』而言,与文件的存在与否没有关系。因为文件记录的是实际的数据。
【2】文件是存放实际数据的所在,那么目录的内容主要在于记录文件名列表,文件名与目录有强烈的关联,所以如果是针对目录时,那么r
,w
,x
对目录的意义如下:
☛ r(read contents in directory)
:表示具有读取目录结构列表的权限,所以当具有读取『r』
一个目录的权限时,表示可以查询该目录下的文件名数据。所以就可以利用ls
指令将该目录的内容列表显示出来。
☛ w(modify contents of directory)
:表示具有如下该目录列表的权限。
○ 建立新的文件与目录
○ 删除已经存在的文件与目录(不论该文件的权限为何)
○ 将已经存在的文件或目录改名
○ 搬移该目录内的文件或目录位置
☛ x(access directory)
:代表用户能够进入该目录成为工作目录的用途,所谓的工作目录(work directory)
就是你目前所在的目录。举例来说,当你登入Linux
时,你所在的家目录就是你当下的工作目录。而变换目录的指令是『cd:change directory』
。
【3】根据上述分析,可以看出,对一般文件来说,rwx
主要针对『文件的内容』来设计权限,对目录而言,rwx
则是针对『目录内的文件名列表』来设计权限。其中最不好理解的就是目录的『x』
权限,可以理解为,如果你在该目录下没有不具有『x』
权限,那么你就无法切换到该目录下,也就无法执行该目录下的任何指令,即使你具有该目录的r或w的权限。所以,通常要开放的目录,至少会具备rx
这两个权限。
六、Linux文件种类与扩展名
【1】文件种类: 我们在看权限的时候,第一栏那十个字符中,第一个字符为文件类型。除了常见的一般文件(-)
与目录文件(d)
之外,还有如下类型。
● 正规文件(regular file)
: 就是一般我们在进行存取的类型的文件,在由ls -al
所显示出来的属性方面,第一个字符为[-]
,例如[-rwxrwxrwx]
。另外,依照文件的内容,又大略可以分为:
- 纯文本档(ASCⅡ)
: 这是Linux
系统中最多的一种文件类型,称为纯文本档是因为内容为我们人类可以直接读到的数据,例如数字、字母等等。几乎只要我们可以用来做为设定的文件都属于这一种文件类型。
- 二进制文件(binary)
: 我们系统其实只认识且可以执行二进制文件。Linux
当中的可执行文件(scripts
,文字型批处理不算),我们常用的Linux
命令就是一个binary file
。
- 数据格式文件(data)
: 有些程序在运作的过程当中会读取某些特定格式的文件,那些特定格式的文件可以被称为数据文件(data file)
。例如,Linux
在使用者登入时,都会将登陆的数据记录在/var/log/wtmp
那个文件内,该文件是一个data file
,它能够通过『last』
指令读出来,但是使用『cat』
时,会读出乱码,因为它是一种特殊的文件格式。
● 目录(directory)
: 第一个字母为d
,表示目录。
● 连结档(link)
: 就类似于Windows
系统底下的快捷键,第一个字母为『l』
(英文字母L
的小写)
● 设备与装置文件(device)
:与系统周边及储存等相关的一些文件,通常都集中在/dev
这个目录下,通常又分为两种:
- 区块(block)设备档: 就是一些存储数据,以提供系统随机存取的接口设备,例如,硬盘与软盘等就是区块设备档。可以随机的在硬盘的不同区块读写,可以查一下/dev/sda
看看,会发现一个属性为『b』
的类型。
- 字符(character)设备文件: 亦既是一些串行端口的接口设备,例如键盘、鼠标等等,这些设备的特色就是『一次性读取』的,不能够截断输出。例如,你不可能让鼠标『跳到』另一个画面,而是『连续性滑动』到另一个地方。
● 资料接口文件(socket)
: 既然被称为数据接口文件,这种类型的文件通常被用到在网络上的数据承接了。我们可以启动一个程序来监听客户端的要求,而客户端就可以透过这个socket
来进行数据沟通了,第一个属性为『s』
,最常在/run
或/tmp
目录下可以看到此类文件目录。
● 数据传输文件(FIFO,pipe)
: FIFO
也是一种特殊的文件类型,它主要的目的在于解决多个程序同时存取一个文件所造成的错误问题。FIFO
是first-in-first-out
的缩写,第一个属性为『p』
。
除了设备文件是我们系统中很重要的文件,最好不要随意修改之外。另外比较有趣的文件就是连结档,可以将其视为一个文件或目录的快捷方式。至于socket
与FIFO
文件比较难理解,因为其与程序(process)
比较有关系,这个等未来了解process
之后,再进行查阅,可以通过man fifo
及man socket
来查阅系统上的说明。
【2】Linux
文件扩展名: 基本上,Linux
的文件是没有所谓的『扩展名』,我们也说过Linux
文件能不能执行与其第一栏的十个属性有关,与文件名一点关系都没有。在Linux
底下,只要你的权限当中具有x
的话,例如[-rwxr-xr-x]
既代表这个文件具有可以被执行的能力。
具有『可执行的权限』与『具有可执行的程序代码』是两回事,在Linux
底下,可以让一个文本文件,例如之前写的text.txt
具有『可执行的权限x
』,但是这个文件明显不能执行,因为它不具有『可执行的程序代码』,而如果将上面『cat』
命令的『x』
拿掉,那么『cat』
将无法被执行。同时,可被执行和可以执行成功也是不一样的,例如上面说的text.txt
具有可执行的能力,但是能不能执行成功,还是要看该文件的内容。
虽然如此,我们仍然希望可以基于扩展名来了解该文件是什么东西,所以,通常我们还是会以适当的扩展名来表示该文件是什么种类。底下罗列一些常用的扩展名:
✔ *.sh
:脚本或批处理文件(scripts)
,因为批处理文件使用shell编写,因此为*.shell;
✔ *Z,*.tar,*.tar.gz,*.zip,*.tgz
:经过打包的压缩文件。这是因为压缩软件分别为 gunzip,tar等等的,由于不同的压缩软件,而取其相关的扩展名;
✔ *.html,*.php
:网页相关文件,分别代表HTML
语法与PHP
语法的网页文件,.html
的文件可以使用网页浏览器直接开启,至于.php
的文件,则可以通过client
端的浏览器来server
端浏览,运行后的网页结果;
基本上,Linux
系统上的文件名真的只是让你了解文件的用途而已,真正的执行与否仍然需要权限的规范才行。
【3】Linux
文件长度限制(了解): 在Linux
底下,使用传统 Ext2/Ext3/Ext4
文件系统以及CentOS 7
当作预设文件系统的xfs
而言,针对文件的档名长度限制为:单一文件或目录的最大容许文件名为255bytes
,以一个ASC
英文占一个bytes
来说,则大约255
个字符长度。若是以每个中文占2bytes
来说,最大档名大约在128
个中文字。
【4】Linux
文件名的限制:由于Linux
在文字接口下的一些指令操作关系,一般在设定 Linux底下的文件名时,最好可以避免一些特殊字符比较好,例如:『 * ? < > ; & [ ] | \ ' " ‘ () { } 』
因为这些符号在文字接口下,是由特殊意义的。另外,文件名的开头为小数点『.』
时,代表这个文件为『隐藏档』。同时,由于指令当中,常常会使用到-option
之类的选项,所以最好也避免在文档的开头使用『-』
或『+』
来命名。
相关文章:

Linux 文件权限
优质博文:IT-BLOG-CN 一、使用者与群组的概念 【1】在Linux里面,任何一个文件都具有[User,Group及Other]三种身份的个别权限:不过需要注意的是root用户,具有所有权限。 ✔ User(文件拥有者):只有文件拥有者…...
IOS Swift 从入门到精通:算术运算,运算符重载,符合赋值运算,比较运算,条件,结合条件,三元运算,Swift语句,范围运算
目录 算术运算符 运算符重载 复合赋值运算符 比较运算符 条件 结合条件 三元运算符 Switch 语句 范围运算符 总结 算术运算符 现在您已经了解了 Swift 中的所有基本类型,我们可以开始使用运算符将它们组合在一起。运算符是那些像和 这样的小数学符号-&…...

Flutter开发环境搭建和调试
[你的Flutter文件夹路径]\flutter\bin 这样我们的Flutter SDK的环境变量就配置完毕了。接下来在命令提示符窗口中输入命令: flutter doctor 它可以帮助我们检查Flutter环境变量是否设置成功,Android SDK是否下载以及配置好环境变量等等。如果有相关的…...

【IC验证】UVM实验lab03
1. TLM端口的创建、例化与使用 创建: uvm_get_blocking_port #(fmt_trans) mon_bp_port; 例化: function new(string name "mcdf_refmod", uvm_component parent);super.new(name, parent);fmt_trans new("fmt_trans", this);…...
document.write()方法总结
document.write()方法总结 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!document.write()方法是JavaScript中用于向HTML文档写入内容的方法之一。它允许我们在…...
C#循环语句总结
前言 正所谓磨刀不误砍柴工,C#上位机软件开发能力的提升离不开对C#语法的精通,本文接着讲解C#语法知识中的循环语句,在C#程序开发中我们经常会用到各种循环语句,常见的有for循环、while循环,本文就是对C#中用到的各种…...

Spring-bean
Spring 网站:spring.io 两个方面: 简化开发: IoCAOP 框架整合: MyBatis SpringFrameWork系统架构(上层依赖下层) 解决问题(代码耦合度高——模块与模块之间的依赖程度) 目标&am…...

Linux常用命令(14)—查看文件内容(有相关截图)
写在前面: 最近在学习Linux命令,记录一下学习Linux常用命令的过程,方便以后复习。仅供参考,若有不当的地方,恳请指正。如果对你有帮助,欢迎点赞,关注,收藏,评论…...

【html】用html+css实现银行的账户信息表格
我们先来看一看某银行的账户信息表格 我们自己也可以实现类似的效果 效果图: 大家可以看到,其实效果差不多 接下来看看我们实现的代码 源码: <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"&…...

两种单例模式(保证线程安全)
开始前,球球各位读者给个三连吧,有错误感谢指出,谢谢 单例模式也叫单个实例,也就是这个类只有且只能有一个实例对象,这样一个类就叫做“单例”;单例模式有很多种,这里只介绍“饿汉模式”和“懒…...
开发 Golang 项目的 Docker 化案例
开发 Golang 项目的 Docker 化案例 在这个案例中,我们将展示如何使用 Docker 容器化一个简单的 Golang Web 应用。我们将创建一个基于 Go 的 Hello World 应用,并使用 Docker 和 Docker Compose 管理容器化环境。 1. 创建 Golang Web 应用 首先&#…...
PHP面试宝典之Laravel篇
Laravel简介 Laravel是一种优雅的PHP Web应用程序框架,它具有简洁、优雅的语法,并提供了强大的工具用于构建大型、健壮的应用程序。Laravel采用了现代PHP开发的最佳实践,因此深受开发者欢迎。 Laravel面试常见问题 1. 什么是Laravel中间件…...

自动驾驶仿真:Carsim转向传动比设置
文章目录 一、转向传动比概念二、设置转向传动比1、C factor概念2、Steer Kinematics概念3、传动比计算公式 三、转向传动比验证 一、转向传动比概念 转向传动比(Steering Ratio)表示方向盘转动角度与车轮转动角度之间的关系。公式如下: 转向…...
PyTorch nn.CrossEntropyLoss() 交叉熵损失函数详解和要点提醒
文章目录 前置知识nn.CrossEntropyLoss() 交叉熵损失参数数学公式带权重的公式(weight)标签平滑(label_smoothing) 要点 附录参考链接 前置知识 深度学习:关于损失函数的一些前置知识(PyTorch Loss&#x…...
DW学习笔记|数学建模task2
本章主要涉及到的知识点有: 微分方程的解法如何用 Python 解微分方程偏微分方程及其求解方法微分方程的基本案例差分方程的求解数值计算方法元胞自动机 2.1 微分方程的理论基础 微分方程是什么?如果你参加过高考,可能在高三备考中遇到过这…...

【大数据 复习】第9章 数据仓库分析工具Hive
一、概念 1.概述 (1)Hive是一个构建于Hadoop顶层的数据仓库工具。 (2)某种程度上可以看作是用户编程接口,本身不存储和处理数据。 (3)依赖分布式文件系统HDFS存储数据。 (4…...

ionic7 从安装 到 项目启动最后打包成 apk
报错处理 在打包的时候遇到过几个问题,这里记录下来两个 Visual Studio Code运行ionic build出错显示ionic : 无法加载文件 ionic 项目通过 android studio 打开报错 capacitor.settings.gradle 文件不存在 说明 由于之前使用的是 ionic 3,当时打包的…...

setInterval 定时任务执行时间不准验证
一般在处理定时任务的时候都使用setInterval间隔定时调用任务。 setInterval(() > {console.log("interval"); }, 2 * 1000);我们定义的是两秒执行一次,但是浏览器实际执行的间隔时间只多不少。这是由于浏览器执行 JS 是单线程模式,使用se…...
Stable Diffusion Model网站
Civitai Models | Discover Free Stable Diffusion Modelshttps://www.tjsky.net/tutorial/488https://zhuanlan.zhihu.com/p/610298913超详细的 Stable Diffusion ComfyUI 基础教程(一):安装与常用插件 - 优设网 - 学设计上优设 (uisdc.com)…...

K8S - 实现statefulset 有状态service的灰度发布
什么是灰度发布 Canary Release 参考 理解 什么是 滚动更新,蓝绿部署,灰度发布 以及它们的区别 配置partition in updateStrategy/rollingUpdate 这次我为修改了 statefulset 的1个yaml file statefulsets/stateful-nginx-without-pvc.yaml: --- apiVe…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...
【Linux】C语言执行shell指令
在C语言中执行Shell指令 在C语言中,有几种方法可以执行Shell指令: 1. 使用system()函数 这是最简单的方法,包含在stdlib.h头文件中: #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...

基于Flask实现的医疗保险欺诈识别监测模型
基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施,由雇主和个人按一定比例缴纳保险费,建立社会医疗保险基金,支付雇员医疗费用的一种医疗保险制度, 它是促进社会文明和进步的…...
【解密LSTM、GRU如何解决传统RNN梯度消失问题】
解密LSTM与GRU:如何让RNN变得更聪明? 在深度学习的世界里,循环神经网络(RNN)以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而,传统RNN存在的一个严重问题——梯度消失&#…...
【磁盘】每天掌握一个Linux命令 - iostat
目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat(I/O Statistics)是Linux系统下用于监视系统输入输出设备和CPU使…...
汇编常见指令
汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX(不访问内存)XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...
laravel8+vue3.0+element-plus搭建方法
创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...
Spring是如何解决Bean的循环依赖:三级缓存机制
1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间互相持有对方引用,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...