Linux笔记:权限管理、用户和用户组

2024-05-01 06:48

本文主要是介绍Linux笔记:权限管理、用户和用户组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Linux 中的权限种类

  • read :可读 数字代号:4
  • write :可写 数字代号:2
  • execute :可执行 数字代号:1

补充:

  • 拥有全部权限是:7(4+2+1)
  • 拥有可读可执行是:5(4+1)
  • 其他权限任意组合即可!

不同权限的含义

代表字符权限对文件的含义对目录的含义
r读权限可以查看文件内容可以列出目录中的内容
w写权限可以修改文件内容可以在目录中创建、删除文件
x执行权限可以执行文件可以进入目录

Linux的用户分类

  • user(ownere) 所有者
  • group 所属组
  • other 其他人

查看文件的权限

  • 根据以上权限和分类可知,组合起来:3*3 = 9种
  • 执行 $ls -l 列出文件列表
    • 如:-rw-r--r-- 中第一个-表示普通文件类型
    • rw-表示所有者的可读、可写、不可执行的权限
    • r-- 中间三个表示所属组拥有可读、不可写、不可执行的权限
    • r-- 最后三个表示其他人的权限同上

用户组的管理命令

  • groupadd 添加用户组
  • groupdel 删除用户组

用户的管理命令

  • useradd 添加用户
    • -g 制定用户组
    • -m 自动创建宿主目录(ubuntu) centos会默认创建
  • userdel 删除用户
    • -r 连同宿主目录一起删除
  • passwd 修改用户密码(没有参数时修改自己的密码)

权限操作命令

  • chown jack test.txt

    • chown 表示 change owner 改变所有者
    • 整条命令表示:修改test.txt文件的所有者为jack
  • chgrp group1 test.txt

    • chgrp 表示 change group 改变群组
    • 整条命令表示:修改test.txt文件的所属组为group1
  • chmod u+x ./go.sh

    • chmod 表示 change mod 改变权限
    • 整条命令表示:修改当前目录下的go.sh文件的拥有者权限添加可执行
  • chmod -R 777 /data/www

    • -R 是目录下所有文件,777就是高权限(读、写、执行)
    • 整条命令表示:将/data/www目录下的所有文件权限修改成可读可写可执行

通过实例来进行权限操作

1 ) 任务

  • 创建2个小组

    • python
    • php
  • 创建4个用户分到上述两组中

    • python: jack mary
    • php: lily tom
  • 创建目录

    • /data/python
    • /data/php
  • 配置权限

    • python 组的同事允许在 /data/python 目录下工作
    • php 组的同事允许在/data/php目录下工作

2 ) 操作

  • 在root权限下操作

    # 创建两个组
    groupadd pyhton
    groupadd php# 分别在两个组下创建两个用户
    useradd -m -g python jack
    useradd -m -g python maryuseradd -m -g php lily
    useradd -m -g php tomls /home/ # 查看用户目录
    jack joe lily mary tom # 此处是输出信息# 创建目录 不能一次创建多层目录,如果需要,要加参数 -p
    mkdir /data/python -p
    mkdir /data/phpcd /data
    ls
    php python # 此处是输出信息# 处理jack用户
    passwd jack # 给jack用户设置密码
    Enter new UNIX password:
    Retype new UNIX password:
    passwd: password updated successfully
  • 登录jack用户

    # 查看当前目录
    pwd
    /home/jack # 此处是输出信息# 切换到data目录
    cd /data
    ls -l
    total 8 # 此处是输出信息
    drwxr-xr-x 2 root root 4098 Dec 15 22:00 php # 此处是输出信息
    drwxr-xr-x 2 root root 4098 Dec 15 22:00 python # 此处是输出信息# 目前jack属于other群组,在other群组中的权限是 r-x 可读、可执行
    cd python # 因为可执行所以可切换
    touch x.py # 尝试创建文件
    touch: cannot touch 'x.py': Permission denied # 此处是输出信息 可见提示无法创建,缺少权限(-w 写权限)
  • 目前jack无法再python目录中写操作,我们切换到root权限下,将python目录转让给jack

    # 在/data目录下
    chown jack python/
    ls -l
    total 8 # 此处是输出信息
    drwxr-xr-x 2 root root 4096 Dec 15 22:00 php # 此处是输出信息
    drwxr-xr-x 2 jack root 4096 Dec 15 22:00 python # 此处是输出信息
  • 验证权限是否配置成功,切换到jack用户下

    touch x.py
    # 发现这时候已经可以正常创建了
    
  • 同理测试mary用户,在root用户下,给mary设置密码

    passwd mary # 给mary用户设置密码
    Enter new UNIX password:
    Retype new UNIX password:
    passwd: password updated successfully
    
  • 再登录mary用户,发现和之前jack一样无法在python目录下创建文件

    # 此时同理mary在刚刚登录时候,在/data/python目录上也是没有写权限的
    # 但是我们不能再像给jack权限一样,把目录转让给mary,这样jack会失去权限
    # 我们可以考虑将写权限归到小组中去,将mary加入到相应的组中去即可
    
  • 切换到root用户,处理mary的相关权限

    # 在/data目录下操作 将python目录加入到python组中
    chgrp python python/
    ls -l
    total 8 # 此处是输出信息
    drwxr-xr-x 2 root root   4096 Dec 15 22:00 php # 此处是输出信息
    drwxr-xr-x 2 jack python 4096 Dec 15 22:00 python # 此处是输出信息 发现python组是r-x,依然没有写权限# 给所属组加上可写的权限即可
    chmod g+w python/ # 这个命令表示 将python目录给所属组加上写权限; g代表所属组(u代表所有者, o代表其他) + 代表加权限 (- 代表减权限)# 再次查看权限
    ls -l
    total 8 # 此处是输出信息
    drwxr-xr-x 2 root root   4096 Dec 15 22:00 php # 此处是输出信息
    drwxrwxr-x 2 jack python 4096 Dec 15 22:00 python # 此处是输出信息 发现所属组新增了写权限:rwx
  • 由于在创建mary用户时分配到了python组,切换到mary用户,这时候发现mary便可以进行写权限了

    # 在python目录下
    touch y.py # 此时可以正确创建# 再次查看
    ls -l
    total 0
    -rw-r--r-- 1 jack python 0 Dec 15 22:03 x.py
    -rw-r--r-- 1 mary python 0 Dec 15 22:06 y.py# mary想要操作jack创建的x.py文件 此时同样是 Permission denied
  • 切换到root用户,我们可将x.py文件对组内可写

    # 在python目录下
    chmod g+x x.py # 此时将x.py文件在组内可写
    
  • 再次切换到mary用户,发现x.py在组内可写了, 此处不再赘述。

  • 同理,按同样的方式将lily、tom添加进php组中即可,任务完成 job done!

更简便的进行权限操作示例

  • 再次切换到root用户下,使用root权限

    # 在python目录下
    chmod 777 x.py
    ls -l
    total 4 # 此处是输出信息
    -rwxrwxrwx 1 jack python 30 Dec 15 22:03 x.py # 此处是输出信息 发现 x.py文件在所有组下拥有了全部权限
    -rw-r--r-- 1 mary python  0 Dec 15 22:06 y.py # 此处是输出信息# 再次修改权限, 只给拥有者全部权限,群组和其他无权限
    chmod 700 x.py
    ls -l
    total 4 # 此处是输出信息
    -rwx------ 1 jack python 30 Dec 15 22:03 x.py # 此处是输出信息 发现只有所有者拥有全部权限,群组和其他都没有权限了
    -rw-r--r-- 1 mary python  0 Dec 15 22:06 y.py # 此处是输出信息

这篇关于Linux笔记:权限管理、用户和用户组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950982

相关文章

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Linux使用scp进行远程目录文件复制的详细步骤和示例

《Linux使用scp进行远程目录文件复制的详细步骤和示例》在Linux系统中,scp(安全复制协议)是一个使用SSH(安全外壳协议)进行文件和目录安全传输的命令,它允许在远程主机之间复制文件和目录,... 目录1. 什么是scp?2. 语法3. 示例示例 1: 复制本地目录到远程主机示例 2: 复制远程主

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、