Python基础到实战一飞冲天(一)--linux基础(七)修改权限chmod
nanshan 2025-01-02 18:06 13 浏览 0 评论
# 07_ Python基础到实战一飞冲天(一)--linux基础(七)--修改权限chmod-root-groupadd-groupdel-chgrp-username-passwd
## 一、用户权限-02-用户/权限/组的基本概念
### 1、**用户** 和 **权限** 的基本概念
1) **用户** 是 Linux 系统工作中重要的一环,用户管理包括 **用户** 与 **组** 管理。
2) 在 Linux 系统中,不论是由本机或是远程登录系统,每个系统都**必须拥有一个账号**,并且**对于不同的系统资源拥有不同的使用权限**。
3) 在 Linux 中,可以指定 **每一个用户** 针对 **不同的文件或者目录** 的 **不同权限**。
### 2、对 **文件/目录** 的权限包括:
序号 | 权限 | 英文 | 缩写 | 数字代号 |
1 | 读 | read | r | 4 |
2 | 写 | write | w | 2 |
3 | 执行 | excute | x | 1 |
### 3、 组
1)为了方便用户管理,提出了 **组** 的概念,如下图所示
2)在实际应用中,可以预先针对 **组** 设置好权限,然后 **将不同的用户添加到对应的组中**,从而**不用依次为每一个用户设置权限**。
## 二、用户权限-03-ls -l输出信息介绍
### 1、 ls -l 命令 扩展
* `ls -l` 可以查看文件夹下文件的详细信息,从左到右依次是:
* **权限**,第 1 个字符如果是 `d` 表示目录,是 - 表示文件。三个字母为一组,分 别表示:读、写、执行权限,- 表示无任何权限。
* **硬链接数**,通俗地讲,就是有多少种方式,可以访问到当前目录/文件。
* **拥有者**,家目录下 文件/目录 的拥有者通常都是当前用户。
* **组**,在 Linux 中,很多时候,会出现组名和用户名相同的情况。
* **大小**
* **时间**
* **名称**
### 2、文件和目录权限示例图:
### 3、ls -l 命令示例:
## 三、用户权限-03-ls -l硬链接数含义的扩展
### 1、ls -l 查看到 硬链接数
硬链接数**,通俗地讲,就是有多少种方式,可以访问到当前目录/文件,目录硬链接数通常取决于目录有多少子目录。
### 2、硬链接数变化,演示:
## 四、用户权限-04-chmod修改文件权限
### 1、`chmod` 简单使用(重要)
1) `chmod` 可以修改 **用户/组** 对 **文件/目录** 的权限
2)命令格式如下:
```bash
chmod +/-rwx 文件名|目录名
```
> 提示:以上方式会一次性修改 `拥有者` / `组` 权限。
### 2、chmod 修改文件权限 示例:
```bash
#chmod 修改 b 文件权限:取消读、写权限,就不能打开和编辑了。
chmod -rw b
#chmod 修改 b 文件权限:添加读权限、但没有写权限,能打开不能编辑(只读)。
chmod +r b
#chmod 修改 b 文件权限:添加读/写权限,能打开也能编辑(Ctrl +s 保存)。
chmod +w b
#更改文件名 b 为 b.py 并添加执行权限(文件变成绿色)
mv b b.py
chmod +x b.py
#执行文件 b.py 输出 hello world
python@Ubuntu:~/桌面$ ./b.py
hello world
```
## 五、用户权限-05-chmod修改目录权限
### 1、`chmod` 对 **目录** 的权限修改
```bash
#命令格式如下:
chmod +/- rwx 文件名|目录名
#python用户创建新目录test(默认谁创建谁具有可读可写可执行的权限)
mkdir test
#查看权限
ls -l
ls test
cd test
#修改 test 目录权限:取消可执行权限
chmod -x test
#取消 test 目录可执行权限后,查看,进入 test 目录都受限
#添加可执行权限
python@Ubuntu:~/桌面$ chmod -x test
python@Ubuntu:~/桌面$ ls -l
总用量 28
-rw-rw-r-- 1 python python 123 11月 7 00:16 321.txt
drwxrwxr-x 3 python python 4096 11月 7 00:35 a
-rw-rw-r-- 1 python python 662 11月 7 00:41 aa
drwxrwxr-x 4 python python 4096 11月 7 22:13 aaa
-rwxrwxr-x 1 python python 40 11月 7 22:39 b.py
-rw-rw-r-- 1 python python 542 11月 6 23:49 readme.txt
drw-rw-r-- 2 python python 4096 11月 7 22:57 test
python@Ubuntu:~/桌面$ cd test
bash: cd: test: 权限不够
python@Ubuntu:~/桌面$ ls test
#添加可执行权限
python@Ubuntu:~/桌面$ chmod +x test
python@Ubuntu:~/桌面$ touch test/01.py
#删除读、写权限
python@Ubuntu:~/桌面$ chmod -rw test
python@Ubuntu:~/桌面$ ls test
ls: 无法打开目录'test': 权限不够
python@Ubuntu:~/桌面$ touch test/02.py
touch: 无法创建'test/02.py': 权限不够
#添加写权限
python@Ubuntu:~/桌面$ chmod +w test
python@Ubuntu:~/桌面$ touch test/02.py
python@Ubuntu:~/桌面$ ls test
01.py 02.py
```
### 2、chmod 修改目录权限 示例
## 六、用户权限-06-超级用户介绍
### 1、超级用户root
- Linux 系统中的 `root` 账号通常 **用于系统的维护和管理**,对操作系统的所有资源 **具有所有访问权限**。
2)在大多数版本的 Linux 中,都不推荐 **直接使用 root 账号登录系统**。
3)在 Linux 安装的过程中,系统会自动创建一个用户账号,而这个默认的用户就称为“标准用户”。
### 2、 sudo 命令
1) `su` 是 `substitute user` 的缩写,表示 **使用另一个用户的身份**。
2) `sudo` 命令用来以其他身份来执行命令,预设的身份为 `root`。
3) 用户使用 `sudo` 时,必须先输入密码,之后有 **5 分钟的有效期限**,超过期限则必须重新输入密码。
> 若其未经授权的用户企图使用 `sudo`,则会发出警告邮件给管理员。
## 七、组管理-01-添加组/删除组/确认组信息
### 1、**组管理** 终端命令
1) 提示:**创建组** / **删除组** 的终端命令都需要通过 `sudo` 执行
2)组管理命令与作用
序号 | 命令 | 作用 |
1 | groupadd 组名 | 添加组 |
2 | groupdel 组名 | 删除组 |
3 | cat /etc/group | 确认组信息 |
tail -3 /etc/group | ||
4 | chgrp -R 组名 文件/目录名 | 递归修改文件/目录的所属组 |
3)提示:
> * 组信息保存在 `/etc/group` 文件中。
> * `/etc` 目录是专门用来保存 **系统配置信息** 的目录。
4)组示例图
5) 在实际应用中,可以预先针对 **组** 设置好权限,然后 **将不同的用户添加到对应的组中**,从而**不用依次为每一个用户设置权限**。
### 2、组管理命令 演练
```bash
sudo groupadd dev
cat /etc/group
sudo groupdel dev
Tail -3 /etc/group
```
## 八、组管理-02-群组演练目标确定
### 1、组管理命令演练目标
1)在 `python` 用户的桌面文件夹下创建 `Python学习` 目录。
2) 新建 `dev` 组。
3)将 `Python学习` 目录的组修改为 `dev`。
### 2、修改目录组命令:chgrp
chgrp 命令格式:
chgrp -R 组名 文件/目录名 (递归修改文件/目录的所属组)。
## 九、组管理-03-chgrp修改目录所属组的演练
### 1、组管理命令演练实操
```bash
#1)在 `python` 用户的桌面文件夹下创建 `Python学习` 目录。
cd ~/Desktop
mkdir Python学习
#2) 新建 `dev` 组。
sudo groupadd dev
#3)将 `Python学习` 目录的组修改为 `dev`。
Ls -l
sudo chgrp -R dev Python学习
```
### 2、修改目录组命令:chgrp 实操
## 十、用户管理-01-新建用户useradd和passwd
### 1、 **用户管理** 终端命令
> 提示:**创建用户** / **删除用户** / **修改其他用户密码** 的终端命令都需要通过 `sudo` 执行。
序号 | 命令 | 作用 | 说明 |
1 | useradd -m -g 组 新建用户名 | 添加新用户 | -m 自动建立用户家目录 -g 指定用户所在的组,否则会建立一个和同名的组 |
2 | passwd 用户名 | 设置用户密码 | 如果是普通用户,直接用 passwd 可以修改自己的账户密码 |
3 | userdel -r 用户名 | 删除用户 | -r 选项会自动删除用户家目录 |
4 | cat /etc/passwd \ | grep 用户名 | 确认用户信息 (新建用户后,用户信息会保存在 /etc/passwd 文件中 ) |
### 2、提示:
> * 创建用户时,如果忘记添加 `-m` 选项指定新用户的家目录 —— 最简单的方法就是**删除用户,重新创建**。
> * 创建用户时,默认会创建一个和**用户名**同名的**组名**。
> * 用户信息保存在 `/etc/passwd` 文件中。
### 3、示例演练
```bash
#创建一个zhangsan用户和家目录,并让它属于dev用户组
sudo useradd -m -g dev zhangsan
#查看家目录下详细信息
ls -l /home
#给用户zhangsan 添加密码
sudo passwd zhangsan
```
`上一节关联链接请点击:`
相关推荐
- 0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)
-
文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...
- ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes
-
为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...
- 生产环境starrocks 3.1存算一体集群部署
-
集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...
- 在CentOS上添加swap虚拟内存并设置优先级
-
现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...
- 国产深度(deepin)操作系统优化指南
-
1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...
- postgresql-15.4 多节点主从(读写分离)
-
1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...
- Docker 容器 Java 服务内存与 GC 优化实施方案
-
一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...
- 虚拟内存设置、解决linux内存不够问题
-
虚拟内存设置(解决linux内存不够情况)背景介绍 Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...
- Elasticsearch性能调优(5):服务器配置选择
-
在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...
- Es如何落地
-
一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...
- 针对Linux内存管理知识学习总结
-
现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...
- MySQL进阶之性能优化
-
概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...
- Linux Cgroups(Control Groups)原理
-
LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...
- linux 常用性能优化参数及理解
-
1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...
- 如何在 Linux 中使用 Sysctl 命令?
-
sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)