linux命令行与shell脚本大全——学习笔记(7-8章)

第7章 理解Linux文件权限

用户、用户组、其他用户

用户权限是通过创建用户时分配的用户 ID(user ID,UID)来跟踪的。UID 是个数值,每个
用户都有一个唯一的 UID。但用户在登录系统时是使用登录名(login name)来代替 UID 登录的。
登录名是用户用来登录系统的最长 8 字符的字符串(字符可以是数字或字母),同时会关联一个对应的密码

添加新用户useradd

useradd默认值

默认值可以通过useradd -D查看
某些linux环境useradd默认不创建home目录,使用useradd -m username可以创建,同时会复制/etc/skel目录下所有文件到新用户的$HOME目录下。

创建用户使用其他参数

如-m是创建用户$HOME目录,-g指定用户登录的GID或组名,-r创建系统账户,-p passwd指定密码等等,看起来常用的都列举出来了

userdel删除用户

默认只删除etc/passwd/etc/shadow中的用户信息,其他用户相关文件不删除。
加入-r选项,会删除用户的 H O M E 目录和邮件目录,注意使用 ‘ − r ‘ 选项前,确认 HOME目录和邮件目录,注意使用`-r`选项前,确认 HOME目录和邮件目录,注意使用r选项前,确认HOME目录下没有其他用户需要用到的文件

修改用户

usermod

-L:锁定账户,禁止登录
-U:解除锁定,恢复登录

passwd和chpasswd

passwd username:不加username是修改自己密码,加是修改别人密码,只有root用户才能修改别人密码(sudo也可以)
chpasswd可以为大量用户修改密码,直接从txt文件读取账户密码对,实际使用应该很少,用时再查就行,具体略

chsh/chfn/chage

chsh、chfn 和 chage 用于修改特定的账户信息。chsh 命令可以快速修改默认的用户登录shell,chfn 命令提供了在/etc/passwd 文件的备注字段中保存信息的标准方法,chage 命令可用于帮助管理用户账户的有效期。知道有这些功能就行了,具体使用时可以搜索

使用Linux组

组权限允许多个用户对系统对象(比如文件、目录或设备等)共享一组权限

/etc/group文件

对于系统账户组,为其分配的 GID 值低于 500,而普通用户组的 GID 则从 500 开始分配
添加组成员使用usermod命令

groupadd创建新组

创建完新组后无用户,使用usermod -G groupname username

groupmod修改组

groupmod可以修改组id或组名,修改组名命令:
groupmod -n newName oldName

理解文件权限

ls -l列举文件权限,第一列形如drwxr-x---,都知道-代表文件,d代表目录(directory),l代表链接(link),c代表字符设备(code),b代表块设备(block),p代表具名管道,s代表网络套接字(socket)
r/w/x分别是read、write、exexutable
9个字符分为3组,分别代表属主权限(这个文件所属人的权限),数组权限(这个文件所属组的权限),系统其他用户

同样地,也可以用二进制表示权限,3位二进制分别代表r/w/x,如100,就是r有权限,w和x没有,010是没有r权限,有w权限,没有x权限等,将2进制转化为8进制,就可以直接设置权限了!
chmod 777 filename,7就是2进制的111,也就是4®+2(w)+1(x),即完整权限,这个命令给所属用户,用户组,其他用户都是所有权限

以下用drwxr-xr-x举例说明:

drwxr-xr-x
文件类型,-代表文件,d代表目录,等等文件所属用户有可读权限,权限加4可写,+2可执行,+1

默认文件权限

首先,要知道文件和目录,全权限值是不一样的,文件全权限值是666,目录全权限值是777,因为要能进目录,必须有可执行权限。
那么用户创建一个新文件,文件权限是多少呢?可以使用umask看看掩码是多少
umask:查看用户权限,是0022
touch newfile.txt:发现新创建文件权限是-rw-r--r--,是从666里,减去022(每位减),即剩下644
mkdir testMaskFile:发现创建目录权限是drwxr-xr-x,是从777里,减去022,即权限为755
umask还可以修改默认权限掩码,如umask 026,再创建文件,权限就会变为-rw-r-----,即666减026,变成640

更改安全设置

修改权限chmod

通常命令为chmod options mode file

八进制编码设置:chomod 666 text.txt

最常用就是直接按文件的标准 3 位八进制权限编码设置,如chmod 666 test.txt

符号模式设置:chmod o+r text.txt

o+r:o定义权限作用对象,+定义操作,r定义操作权限,以下列举三种对象的值:
1.权限作用对象:

权限作用对象含义
u用户
g
o其他用户
a上述所有用户

2.操作

操作含义
+增加权限
-移除权限
=设置权限

3 要设置的权限

要设置的权限含义
r
w
x执行
X仅当对象是目录或者已有执行权限时才赋予执行权限
s在执行时设置 SUID 或 SGID
t设置粘滞位(sticky bit)
u设置属主权限
g设置属组权限
o设置其他用户权限

注意要设置的权限比想象中的rwx多了X/s/t/u/g/o这些,这些暂时不重要,知道有就行

选项-R

chmod几乎只需要记住-R选项即可,表示递归修改

改变所属关系:chown/chgrp

修改文件所属用户:chown

chown options owner[.group] file:修改文件所属用户,也可以直接修改文件所属用户和用户组
1 直接修改文件所属用户chown username filename
2 修改文件所属用户和用户组:chown username.groupname filename
chgrp同理,直接修改文件所属用户组

共享文件

大概就是SUID,SGID,粘滞位(sticky bit),目的就是新创建的文件,可以通过设置SGID位,让目录下的所有文件都默认使用某个组而不是用户本身的组,感觉重要但是又没那么重要,知道有这个功能就行,需要用到再查

访问控制列表ACL

原文定义比较复杂,实际可以理解为:同样的文件,对于不同的用户/用户组,有自己不同的权限。
要想实现acl,实际的命令就是setfaclgetfacl。原书讲了很多这两个命令的参数,含义,但实际上最新版的linux基本都不内置这两个命令了,而且实际使用场景也不多,需要用到再查吧

第八章 管理文件系统

Linux文件系统类型

大概有ext文件系统(ext/ext2),日志文件系统(ext3/ext4/JFS/ReiserFS/XFS),卷管理文件系统(ZFS/Btrfs/Stratis),具体的定义都蛮复杂,可以理解为三种不同维度的文件系统,具体怎么个处理法现在不需要学习。

使用文件系统

文件系统实际上暂时不需要过多了解,先跳过,有时间再看

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分布式锁-快速入门

文章目录 前言一、基础概念1.1 什么是锁1.2 什么是分布式锁1.3 锁和事务的区别二、分布式锁基础理论2.1 为什么要使用分布式锁2.2 分布式锁特性2.3 分布式锁的实现方式总结前言 由于在平时的工作中,线上服务器是分布式多台部署的,经常会面临解决分布式场景下数据一致性的问题…

TRILL解析

Deep Imitation Learning for Humanoid Loco-manipulation through Human Teleoperation解析 摘要1.简介2. Related work2.1 人形机器人的局部操纵2.2 远程操作示范中的模仿学习 3. 方法 论文链接:https://arxiv.org/abs/2309.01952 论文项目:https://ut…

通过mask得到bbox(numpy实现)

在SAM的加持下,我们很容易得到物体的mask,但是物体的bbox信息通常也很有用。那么,我们可以写一个函数,立马可以通过mask得到bbox。 代码如下: import numpy as npdef mask2bbox(mask):nonzero_indices np.nonzero(m…

运维开发工程师教程之MongoDB单机版设置

MongoDB单机版设置 一、创建虚拟机 在VMware Workstation软件中新建一个虚拟机,具体操作步骤如下: ①运行VMware Workstation软件,进入到主界面,单击“创建新的虚拟机”来创建新的虚拟机,如图3-1所示。 图3-1 VMware…

Anaconda安装教程

1Anaconda 简介 Anaconda是一个数据科学平台,提供一个发行版的 Python 以及大量常用的数据科学包、库和工具。通过包含诸如 NumPy、Pandas、SciPy、Matplotlib等核心库,以及 Jupyter Notebook等开发工具,使数据分析、机器学习和数据可视化变…

stm32和树莓派的区别?

在开始前我有一些资料,是我根据网友给的问题精心整理了一份「stm32的资料从专业入门到高级教程」, 点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!Stm32和树莓派是两个不同的领域…

从零搭建xxl-job(一) :单体项目多模块项目搭建

maven配置&#xff1a; 属性解释&#xff1a; <groupId> 在Maven中&#xff0c;groupId是一个项目的唯一标识符&#xff0c;它通常是公司或组织的反向域名&#xff0c;例如com.example.project。groupId在Maven的依赖管理中也非常重要&#xff0c;因为它可以确保依赖项…

百度副总裁秒批离职,00后的职场逆袭?

“员工闹分手提离职我秒批”&#xff0c;百度副总裁璩静的职场经历和思考在近期引发了大量讨论。 璩静在小红书分享了自己作为女性管理者&#xff0c;面对团队内部的感情问题&#xff0c;是如何处理的&#xff1a; “我第一时间就跟这个年轻的女孩子说&#xff0c;你走吧&…

SAP 财务借贷理解

以下只是个人理解&#xff0c;如果觉得有问题&#xff0c;千万别被带偏哈&#xff1a; 1、了解一些俚语&#xff1a; 有借必有贷&#xff0c;借贷必相等 资产 负债 所有者权益 收入 - 费用 利润 T字记账 2、 资产 、负债 、所有者权益、收入 、费用 、 利润 哪些增加或者减少…

如何创建git并上传

Git的配置和上传主要涉及以下步骤&#xff1a; 一、Git的配置 安装Git&#xff1a;首先&#xff0c;你需要在你的计算机上安装Git。这通常可以通过访问Git的官方网站并按照其提供的安装指南来完成。 注册GitHub账户&#xff08;如果你还没有的话&#xff09;&#xff1a;在Gi…

18、ESP32 ESP-NOW 点对点通信

ESP-NOW 是乐鑫自主研发的无连接通信协议&#xff0c;具有短数据包传输功能。该协议使多个设备能够以简单的方式相互通信。 ESP-NOW 功能 ESP-NOW 支持以下功能&#xff1a; 加密和未加密的单播通信;混合加密和未加密的对等设备;最多可携带 250 字节 的有效载荷;发送回调功能…

苹果免签封装的优势和安全风险

哈喽&#xff0c;大家好呀&#xff0c;淼淼又来和大家见面啦&#xff0c;许多小伙伴应该都知道&#xff0c;App Store一直是iOS应用的主要分发渠道&#xff0c;苹果生态系统的监管是十分严格的&#xff0c;以此确保了应用质量与用户的安全。而苹果免签封装则是有一种不需要通过…

【EasySpider】EasySpider+mysql执行配置异常

问题 使用易采集工具操作时候&#xff0c;遇到一个执行异常&#xff0c;后来发现没有选择数据类型 Loading stealth.min.js MySQL config file path: ./mysql_config.json 成功连接到数据库。 Successfully connected to the database. Traceback (most recent call last):…

如何练英语口语?三个简单练习方法

如何练英语口语&#xff1f;在全球化日益加速的今天&#xff0c;英语已经成为了一种必不可少的交流工具。对于很多人来说&#xff0c;尤其是那些想要在国际舞台上崭露头角的人&#xff0c;流利的英语口语更是必不可少的技能。但是&#xff0c;很多人也面临着一个问题&#xff1…

【Flutter】App内购支付集成 Google和Apple支付和服务器验证全流程

Flutter支付集成 前言&#xff1a; 以谷歌内购为例&#xff0c;我们需要做的总共为三步 需要在谷歌市场配置商品&#xff0c;设置测试渠道&#xff0c;配置开发者账号&#xff0c;设置对应权限。配置完商品之后&#xff0c;如何在 Flutter 中获取到商品&#xff0c;购买指定…

Unity技术学习:渲染大量物体的解决方案,外加RenderMesh、RenderMeshInstanced、RenderMeshIndirect的简单使用

叠甲&#xff1a;本人比较菜&#xff0c;如果哪里不对或者有认知不到的地方&#xff0c;欢迎锐评&#xff08;不玻璃心&#xff09;&#xff01; 导师留了个任务&#xff0c;渲染大量的、移动的物体。 寻找解决方案&#xff1a; 当时找了几个解决方案&#xff1a; 静态批处…

手把手教你解决FP独立站收款问题

独立站成为了许多跨境卖家的首选平台&#xff0c;尤其是对于那些销售FP产品的卖家来说&#xff0c;它提供了一个更为宽松的经营环境。然而&#xff0c;FP独立站虽然规避了平台审核的风险&#xff0c;却面临着另一个挑战——收款问题。 由于FP产品属于敏感领域&#xff0c;与普货…

面试集中营—JVM篇

一、JVM内存模型 线程独占&#xff1a;栈&#xff0c;本地方法栈&#xff0c;程序计数器; 线程共享&#xff1a;堆&#xff0c;方法区 虚拟机栈&#xff1a;线程私有的&#xff0c;线程执行方法是会创建一个栈阵&#xff0c;用来存储局部变量表&#xff0c;操作栈&#xff0c;…

淘宝天猫API接口大全:商品详情商品接口,以图搜索淘宝商品接口,拍立淘接口

淘宝天猫API接口为开发者提供了丰富的功能&#xff0c;以下是关于商品详情接口、以图搜索淘宝商品接口以及拍立淘接口的一些介绍&#xff1a; 商品详情接口&#xff1a; 接口功能&#xff1a;允许用户通过商品ID或商品链接获取商品的详细信息&#xff0c;如标题、价格、销量、…

多个开源的js补环境框架测试

原文链接&#xff1a;https://mp.weixin.qq.com/s/uEMFGpE5bqmTvzSgX2twvA 前言 在做js逆向时肯定会遇到补环境的情况&#xff0c;看到github开源了好几个补环境用的框架&#xff0c;这篇文章做个测试&#xff0c;看看哪个比较好用。 https://github.com/pysunday/sdenvhttp…