三、用户权限相关命令

  • 用户 和 权限的基本概念
  • 用户管理 终端命令
  • 组管理 终端命令
  • 修改权限 终端命令

1、用户和权限的基本概念

1.1、基本概念

  • 用户管理包括 用户 与 组 管理
  • linux系统中,不论是由本机或是远程登录系统,每个系统都必须拥有一个账号
    并且对于不同的系统资源用有不同的使用权限
  • 在linux中,可以指定 每一个用户 针对 不同的文件或者目录 的 不同权限
  • 文件 / 目录 的权限包括:
序号 权限 英文 缩写 数字代号
01 read r 4
02 write w 2
03 执行 excute x 1
04 无权限   - 0

1.2、组

  • 为了方便用户管理,提出 组 的概念
  • 实际应用中,可以预先对 组 设置好权限,然后 将不同的用户添加到对应的组中,从而
    不用依次为每个用户设置权限

1.3、ls -l 扩展

  • ls -l 可以查看文件夹下文件的详细信息,从左到右依次是:

    • 权限、第一个字符是 d 表示目录
    • 硬链接数、有多少种方式可以访问到当前目录/文件
    • 拥有者、home目录下 文件/目录 的拥有者通常都是当前用户
    • 组、linux中,很多时候,会出现组名和用户名相同的情况
    • 大小
    • 时间
    • 名称
  目录 拥有者 组权限 其他用户权限
文件权限示例 - r w - r w - r - -
目录权限示例 d r w x r w x r - x

1.4、chmod 简单使用

  • chmod 可以修改 用户/组 对 文件/目录 的权限
  • 命令格式:
$ chmod +/-rwx 文件名/目录名
  • 以上方式会一次性修改 拥有者/组 权限

1.5、超级用户

  • linux系统中的root 账号通常用于系统的维护和管理,对操作系统的所有资源 具有所有访问权限
  • 不推荐直接使用root账号登录系统
  • 在linux安装过程中,系统会自动创建一个用户账号,而这个默认的用户就称为“标准用户”

sudo

  • su 是substitute user的缩写,表示使用另一个用户的身份
  • sudo 命令用来以其他身份来执行命令,预设的身份为root
  • 用户使用sudo时,必须先输入密码,之后有5分钟的有效期限,超过期限则必须重新输入密码

2、组管理终端命令

创建组 / 删除组 的终端命令都需要通过sudo执行

序号 命令 作用
01 groupadd 组名 添加组
02 groupdel 组名 删除组
03 cat /etc/group 确认组信息
04 chgrp [-R] 组名 文件/目录名 修改文件/目录的所属组
  • 组信息保存在/etc/group文件中
  • /etc 目录是专门用来保存 系统配置信息 的目录
  • chgrp的 -R 递归处理,将指定目录下的所有文件及子目录一并处理。

3、用户管理 终端命令

创建用户 / 删除用户 / 修改用户 的终端命令都需要通过sudo执行

 3.1、创建用户 / 设置密码 / 删除用户

序号 命令 作用 说明
01 useradd -m -g 组 新用户名 添加新用户 -m  自动建立用户家目录
-g  指定用户所在的组,否则会建立一个和用户同名的组
02 passwd 用户名 设置用户密码 如果是普通用户,直接用passwd可以修改自己的账户密码
03 userdel -r 用户名 删除用户 -r 选项会自动删除用户家目录
04 cat /etc/passwd | grep 用户名 确认用户信息 新建用户后,用户信息会保存在/etc/passwd文件中
  • 创建用户时,如果忘记添加-m 选项指定新用户的家目录--简单的方法就是删除用户,重新创建
  • 创建用户时,默认会创建一个和用户名同名的组名
  • 用户信息保存在 /etc/passwd 文件中

3.2、查看用户信息

序号 命令 作用
01 id [用户名] 查看用户UID和GID信息
02 who 查看当前所有登录的用户列表
03 whoami 查看当前登录用户的账户名

passwd文件

/etc/passwd  文件存放的是用户的信息,由6个分号组成的7个信息,分别是:

  1. 用户名
  2. 密码(x,表示加密的密码)
  3. UID(用户标识)
  4. GID(组标识)
  5. 用户全名或本地帐号
  6. 家目录
  7. 登录使用的 Shell,就是登录之后,使用的终端命令,ubuntu 默认是 dash

usermod

  • usermod  可以用来设置用户的主组 / 附加组 和登录 Shell,命令格式如下:
  • 主组:通常在新建用户时指定,在etc/passwd 的第4列GID对应的组
  • 附加组:在etc/group中最后一列表示该组的用户列表,用于指定用户的附加权限

设置了用户的附加组之后,需要重新登录才能生效!

# 修改用户的主组(passwd 中的GID)
$ usermod -g 组 用户名 # 修改用户的附加组
$ usermod -G 组 用户名 # 修改用户登录 Shell
$ usermod -s /bin/bash

默认使用useradd 添加的用户是没有权限使用 sudo 以 root 身份执行命令的,
可以使用以下命令,将用户添加到sudo附加组中

usermod -G sudo 用户名

which

  • /etc/passwd  是用于保存用户信息的文件
  • /usr/bin/passwd  是用于修改用户密码的程序

which  命令可以查看执行命令所在位置,例如:

$ which ls

# 输出
# /bin/ls $ which useradd # 输出
# /user/sbin/useradd

bin和sbin

  • 在linux中,绝大多数可执行文件都是保存在 /bin、/sbin、/usr/bin、/usr/sbin
  • /bin  是二进制执行文件目录,主要用于具体应用
  • /sbin  是系统管理员专用的二进制代码存放目录,主要用于系统管理
  • /usr/bin  后期安装的一些软件
  • /usr/sbin 超级用户的一些管理程序

cd 终端命令是内置在系统内核中的,没有独立的文件。

3.3、切换用户

序号 命令 作用 说明
01 su - 用户名 切换用户,并且切换目录 -  可以切换到用户家目录,否则保持位置不变
02 exit 退出当前登录账户  
  • sudo 不接用户,可以切换到root

4、修改文件权限

序号 命令 作用
01 chown 修改拥有者
02 chgrp 修改组
03 chmod 修改权限

命令格式如下:

# 修改文件|目录的拥有者
$ chown 用户名 文件名|目录名 # 递归修改文件|目录的组
$ chgrp -R 组名 文件名|目录名 # 递归修改文件权限
$ chmod -R 755 文件名|目录名
  • chmod 在设置权限时,可以简单地使用三个数字分别对应 拥有者 / 组 / 其他 用户的权限
# 直接修改文件|目录的 读|写|执行 权限,但不能精确到 拥有者|组|其他
$ chmod +/-rwx 文件名|目录名
拥有者 其他
r w x r w x r w x
4 2 1 4 2 1 4 2 1
  • 常见数字组合有(u 表示用户 / g 表示组 / o 表示其他):

    • 777  ===> u=rwx,g=rwx,o=rwx
    • 755  ===> u=rwx,g=r-x,o=r-x
    • 644  ===> u=rw,g=r,o=r

linux常用终端命令(三)用户和权限的更多相关文章

  1. linux常用终端命令(三)远程管理命令

    三.远程管理常用命令 关机/重启 shutdown 查看或配置网卡信息 ifconfig ping 远程登录和复制文件 ssh scp 1.关机/重启 序号 命令 对应英文 作用 01 shutdow ...

  2. linux常用终端命令

    01. 终端命令格式 command [-options] [parameter] 说明: command:命令名,相应功能的英文单词或单词的缩写 [-options]:选项,可用来对命令进行控制,也 ...

  3. linux常用终端命令(一)终端命令格式(二)文件和目录常用命令

    一.linux终端命令格式 1.终端命令格式 command  [-options]  [parameter] 说明: command :命令名,相应功能的英文单词或单词的缩写 [-options] ...

  4. Linux常用基础命令三

    一.ln 软链接 软链接也称为符号链接,类似于 windows 里的快捷方式,有自己的数据块,主要存放 了链接其他文件的路径. 在查看文件目录中,软连接是以'l'开头 创建软链接 ln -s [原文件 ...

  5. Linux常用脚本命令总结

    基本操作 通用操作 1. export 显示所有的环境变量,也可以获取到某个变量的详细信息: export # 显示所有 echo $SHELL # 只显示SHELL 2. whereis 使用系统自 ...

  6. mac 终端 常用命令,MacOS 常用终端命令大全,mac 在当前目录打开终端

    MacOS 常用终端命令大全:目录操作dircmp——比较两个目录的内容——dircmp dir1 dir2文件操作pg分页格式化显示文件内容——pg filenameod——显示非文本文件的内容—— ...

  7. Linux常用基础命令(二)

    Linux常用基础命令 一.-ls--列表显示目录内容 二.-alias--设置别名 三.-du--统计目录及文件空间占用情况 四.-mkdir--创建新目录 五.-touch--创建空文件 六.-l ...

  8. Linux常用基础命令整理:关机命令、查看目录下文件命令等

    Linux常用基础命令整理:关机命令.查看目录下文件命令等 整理了一些Linux常用基础命令,欢迎指正. 首先记住四个热键,学会这四个键,收益一辈子. Tab按键---命令补齐功能Ctrl+c按键-- ...

  9. Linux 常用系统性能命令总结

    Linux 常用系统性能命令 查看系统负载top,free **w/uptime  ** 最后面三个数字表示1分钟,5分钟,15分钟平均有多少个进程占用CPU占用CPU的进程可以是Running,也可 ...

随机推荐

  1. C语言基础语法之指向函数的指针

    指针是C语言的精髓,对于初学者来讲,指针是C语言语法学习中比较难的知识点,而这里面指向函数的指针更是不太容易理解. 下面给大家讲下怎样学习理解C语言中指向函数的指针及编程方法和使用例子. 注意:这是一 ...

  2. axios 是如何封装 HTTP 请求的

    原载于 TutorialDocs 网站的文章<How to Implement an HTTP Request Library with Axios>.译者:zhangbao90shttp ...

  3. 图论——Floyd算法拓展及其动规本质

    一.Floyd算法本质 首先,关于Floyd算法: Floyd-Warshall算法是一种在具有正或负边缘权重(但没有负周期)的加权图中找到最短路径的算法.算法的单个执行将找到所有顶点对之间的最短路径 ...

  4. 利用Apache shiro SimpleHash 加密字符串

    1.导入包 import org.apache.shiro.crypto.hash.SimpleHash; 1 2.代码 import org.apache.shiro.crypto.hash.Sim ...

  5. docker save/load以及export/import使用测试

    对于有些环境需要离线安装的情况,docker以及docker容器都需要能够支持离线安装,对于docker离线安装,比较简单,按照https://www.cnblogs.com/qq931399960/ ...

  6. docker mysql容器的安装使用

    docker拉取镜像的命令为 docker pull image[:TAG] 如果我们想安装的mysql版本不是最新的版本,则需要填充TAG,如果不带上TAG,则默认安装的为最新版本,虽然可以通过do ...

  7. 将蓝牙rssi(信号强度)转换成距离

    遇到一个问题,是将蓝牙rssi(信号强度)转换成距离的问题. 这一问题没有准确的解决办法,但是有人做过一个拟合回归函数,其变化规律比较类似于rssi的变化规律,函数如下: d = ^(abs(rssi ...

  8. LC 740. Delete and Earn

    Given an array nums of integers, you can perform operations on the array. In each operation, you pic ...

  9. Js 监听器

    在Ajax取数据时,采用$("#id").click(function(){})的方式不能正确设置监听,需要用$("#parent").on("cli ...

  10. android stdio 首次安装配置

    http://www.cnblogs.com/smyhvae/p/4390905.html 不启用 加快模拟器调试 这个玩意儿打开老是报什么 android 1.0的问题 导致编译不起来 直接关了 S ...