Linux下用户权限相关命令

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

  • 用户 是Linux系统工作中重要的一环,用户管理包括 用户 管理
  • 在Linux系统中,不论是由本机或是远程登陆系统,每个系统都必须拥有一个账号,并且对于不同的系统资源拥有不同的使用权限
  • 文件/目录 的权限包括:
序号 权限 英文 编写 数字代号
01 read r 4
02 write w 2
03 执行 excute x 1

2、ls-l 扩展

ls-l 可以查看文件夹下文件的详细信息

Linux下用户权限相关命令_第1张图片

  • 第一列字符( - / d ),- 表示文件,对应的文件颜色也为白色;d 表示目录,对应的文件夹颜色为蓝色
  • 第二列字符( r w x),表示 拥有者 可读可写可执行的权限
  • 第三列字符( r w x),表示 可读可写可执行
  • 第四列字符( r w x),表示 其他用户 可读可写可执行
  • 第五列数字,表示硬链接数,通俗讲,就是有多少种方式,可以访问到当前目录/文件
  • 第六列字符( Python ),表示拥有者名称
  • 第七列字符( Python ),表示名称,在Linux中,很多时候,会出现组名和用户名相同的情况
  • 大小
  • 时间
  • 名称

3、修改文件权限

chown 可以修改拥有者

chgrp 可以修改所属组

chmod 可以修改 用户/组文件/目录 的权限

命令格式:

# 修改文件/目录的拥有者
$ chown 用户名 文件名/目录名

# 递归修改文件/目录的组
$ chgrp -R 组名 文件名/目录名

# 递归修改文件权限,+ 表示增加权限,- 表示减少权限,这种修改不能精确到拥有者|组|其他的权限
$ chmod -R +/-rwx 文件名/目录名

# 常用递归修改文件权限,三个数字分别对应 拥有者 | 组 | 其他 用户的权限
$ chmod -R 755 文件名/目录名

Linux下用户权限相关命令_第2张图片

  • 常见数字组合有(u 表示用户 / g 表示组 / o 表示其他):
  • 777 --->  u=rwx,g=rwx,o=rwx
  • 755 --->  u=rwx,g=r-x,o=r-x
  • 444 --->   u=r--, g=r--,o=r--
  • Linux下用户权限相关命令_第3张图片

4、组管理 终端命令

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

序号 命令 作用
01 groupadd 组名 添加组
02 groupdel 组名 删除组
03 cat /etc/group 确认组信息
04 chgrp -R 组名 文件/目录名 递归修改文件/目录的所属组

提示:信息保存在/etc/group文件中,/etc 目录是专门用来保存 系统配置信息 的目录

在实际应用中,可以预先设计 设置好权限,然后 将不同的用户添加到对应的组中,从而不用依次为每一个用户设置权限

5、用户管理 终端命令

提示:创建用户 / 删除用户 / 修改其他用户密码 的终端命令都需要通过sudo执行

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

序号 命令 作用 说明
01 useradd -m -g 组 新建用户名 添加新用户

-m 自动建立用户家目录

-g 指定用户所在组,否则会建立一个和同名的组

02 passwd 用户名 设置用户密码 如果是普通用户,直接用passwd可以修改自己的账户密码
03 userdel -r 用户名 删除用户 -r 选项会自动删除用户家目录
04 cat /etc/passwd | grep 用户名 确认用户信息 新建用户后,用户信息会保存在 /etc/passwd

提示:

  • 创建用户时,如果忘记添加 -m 选项指定新用户的家目录——最简单的方法就是 删除用户,重新创建
  • 创建用户时,默认会创建一个和用户名同名的组名
  • 用户信息保存在 /etc/passwd 文件中

5.2、查看用户信息

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

Linux下用户权限相关命令_第4张图片

passwd文件

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

1.用户名

2.密码(x 表示加密的密码)

3.UID(用户代号标识)

4.GID(用户归属的组的代号标识)

5.用户全名或本地账号

6.用户的家目录

7.登录使用的Shell,就是登录之后,使用的终端命令,ubuntu默认是dash

Linux下用户权限相关命令_第5张图片

usermod

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

Linux下用户权限相关命令_第6张图片

由上图可以看出,用户zhangsan只有主组dev,没有附加组

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

# 修改用户的主组(passwd中的GID)
$ usermod -g 组 用户名

# 修改用户的附加组
$ usermod -G 组 用户名

Linux下用户权限相关命令_第7张图片

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

但是可以从上图看出,dash界面在putty软件中不是很友好,没办法直观区分文件和目录,不能直观的看出当前用户等缺点,

使用下面的命令可以修改用户登录的Shell:

# 修改用户登录 Shell
$ usermod -s /bin/bash 用户名

windows下重新登录zhangsan用户

Linux下用户权限相关命令_第8张图片

which命令

提示:

  • /etc/passwd  用于保存用户信息的文件
  • /usr/bin/passwd 是用于修改用户密码的程序
  • which命令可以查看执行命令所在位置

Linux下用户权限相关命令_第9张图片

上图可以看出,有的文件保存在bin下,有的保存在sbin下

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

5.3 切换用户

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

 

你可能感兴趣的:(Linux)