linux下用户和用户组大全操作

linux下用户和用户组大全操作

一.用户操作

1、创建用户

#adduser tom    //新建tom用户
#passwd tom    // 给tom用户设置密码

增加用户tom,有一点要注意的,useradd增加一个用户后,不要忘了给他设置密码,不然不能登录的。
在这里插入图片描述

2、查看创建用户参数

useradd --help

在这里插入图片描述

3、删除用户

# userdel tom

将tom用户删除

4、查看用户

(1)查看当前登录用户

[root@localhost bin]# w
[root@localhost bin]# who

在这里插入图片描述

(2)查看自己的用户名

[root@localhost bin]# whoami

在这里插入图片描述

(3)查看用户登录记录

[root@localhost bin]# last              //查看登录成功的用户记录
[root@localhost bin]# lastb            //查看登录不成功的用户记录

二、用户/用户组的概念及管理

Linux系统是一个多用户多任务的分时操作系统(Unix),可以理解为同一时间可以有不同用户使用同一操作系统干不同的事情。这些用户可不是同一类人,有的是超级大管家(root),有的是普通小市民(test),它们虽然共同住在一起,但是有些东西并不是普通小市民可以用的,有时候要用还需要临时借用一下sudo命令使用管家的权限。可是能力越大,责任就越大,超级大管家哪一天想不开使用了rm -rf /*,那么恭喜直接牢底坐穿🙃。小市民虽然普通但是遵纪守法绝不会干出格的事情。而正是这样职责明确的系统才让Linux无比强大。让我们进入主题:如何管理用户呢?

2.1、创建新用户

我们最初是有一个root用户默认存在的,它无比强大,但是大家如果和我一样是初学者最好创建一个普通用户来学习,而且最好是在虚拟机中搞,大不了删掉重来。

# 创建一个普通用户(先用root用户登录)
# 可以使用`-g`分配用户组,为了演示groupadd先不加了
useradd  foo

# 修改密码
passwd foo

# 切换用户
su foo

此时我们去home目录下可以看到多了一个文件foo:
在这里插入图片描述
我们可以看到有很多列,但是我们目前只需要关注三列,最左边的(drwx------)是文件/文件夹 的读写或执行权限,中间两个foo一个是目录所有者和目录所有者所在的群组,我们先来说说用户和用户组是啥意思。

2.2、 用户/用户组和uid/gid

假如我们有一个开发部门,部门里面有前端组、测试组、后端组、UI组等小组,而每一个组都具有做一些事情的权利,前端组主要负责开发页面啦、小程序啦、基础组件开发等等,其他组也是类似的,那这些成员就类似于Linux中的用户,而前端组就是用户组,虽然本身这个用户而言它不一定有其他用户的权限,但一定有用户组的权限。

另外每一个用户和所在的组都会有一个唯一的编号来区分其他用户和用户组,这个编号十分重要,就像身份证ID一样。Linux内核可不是根据用户名/用户组名来确定权限的,而是根据uid/gid来区分的。uid 和 gid 由 Linux 内核负责管理,并通过内核级别的系统调用来决定是否应该为某个请求授予特权。比如当进程试图写入文件时,内核会检查创建进程的 uid 和 gid,以确定它是否有足够的权限修改文件。我在学习Docker时常就很困惑容器的用户和宿主机的用户有什么区别,但是理解了uid和gid之后就明白了。

我们可以使用whoami、groups和id命令查看当前用户/用户所在组和uid/gid:

在这里插入图片描述

2.3、用户组的管理

我们创建foo时,如果不分配它所在群组,那么它的用户组默认就是foo,我们可以使用groups命令查看当前用户的群组:

[foo@localhost home]$ groups
foo

那如果我想变更foo的群组呢,原本他搞前端现在想做后端了,这个也是没有问题滴,我们首先要有这个“后端组”嘛,我们先添加一个api组,它的命令和添加用户很类似:

# 先切换到root
su -

# 添加群组api
groupadd api

# 给foo用户分配群组 -g 是修改用户群组的意思
usermod -g api foo

然后我们发现此时foo这个用户所在组从foo变成了api:
在这里插入图片描述
usermod其实就是user+modify的缩写,它是用来修改用户的一个很重要的命令,它必须要在root下运行,后面要介绍的chown也是如此。

现在foo这个小伙子进了api组后总是抱怨自己就是写API的,他又想多加一个front组来写前端,那按上面的步骤再整嘛,不过我们可以这样做,一次性就可以添加多个群组了:

usermod -G api,front foo

但是不管使用-g还是-G参数都会将原来的群组给干掉,如果要保留原来的群组需要加上-a参数,而且这个参数只能与-G一起使用。

注意,很多像我一样刚学Linux系统的朋友,刚开始发现很多命令都会没有权限这很正常,网上也会告诉我们在suders文件中给我们一个使用sudo命令的权限,但是用久了跟使用root没差别的,所以建议刚开始就不要这样弄,现在虽然麻烦了点,但是方便理解它的权限控制系统。

3、文件权限管理

我们知道了用户与用户群组的概念后,下面进入一个十分重要的环节:文件权限。

在这里插入图片描述
第一列这么一大串是个什么玩意?

我们先了解一下那些小写的英文字母代表什么吧:

  • d(directory):说明当前是一个文件夹
  • l(link):说明是一个链接
  • r(read):说明文件可读
  • w(write):说明文件可写,当然也可以被删除
  • x(execute ):可以运行该文件

我们可以看到有很多重复的出现,并且串在一起很难看懂,不过我们有了上面的铺垫后就很容易理解啦~
首先-代表一个坑位,如果没有任何英文字母的情况会有10个坑位,最后一个 . 代表结束,第一个坑位可以是 l、d、- 分别表示当前是一个链接、目录、文件,而后面每三个一组代表文件所有者、群组用户、其他用户的权限。用一张画得比较丑的图来看看
在这里插入图片描述
下面我们来看看如何分配权限吧。

3.1、使用数字表述权限

使用数字分配权限比较方便和常用,w、r、x分别对应4、2、1,分配权限的时候只需要把对应的数字加起来就可以了,我们先创建一个test.txt 文件并写入’hello’:

echo 'hello' > test.txt

此时的文件权限是622:
在这里插入图片描述

那么我们现在给这个文件分配760权限(为了演示),也就是群组可读可写,其他用户任何权限,我们使用chmod这个命令来分配:

此时我们用 ll 命令来查看:
在这里插入图片描述

可见,权限成功分配成功了,是不是很开心呢~我们再用图来看看:

在这里插入图片描述
我们经常看到的777其实就是所有用户都有读写可执行权限,其他的大家可以自己推算出来。我们经常看到用sudo去执行这个chmod命令,其实没必要的,给文件分配权限只有两种可能,一个是文件的所有者,另外一个是root,可以理解我们在foo自个儿的家里玩,想咋整就咋整咯。除了用数字来表示权限,还有一种是用字母表示。

3.2、用字母分配权限

我们一般会用下面三个符号来分配权限:

+:增加某个权限
-:移除某个权限
=:分配某个权限
用u、g和o来表示当前用户、用户组、其他用户,我们来看几个例子就明白啦~

#文件 test.txt 的所有者增加读和运行的权限。
chmod u+rx test.txt

#文件 test.txt 的群组其他用户增加读的权限。
chmod g+r test.txt 

#文件 test.txt 的其他用户移除读的权限。
chmod o-r test.txt 

#文件 test.txt 的群组其他用户增加读的权限,其他用户移除读的权限。
chmod g+r o-r test.txt 

#文件 test.txt 的群组其他用户和其他用户均移除读的权限。
chmod go-r test.txt 

#文件 test.txt 的所有用户增加运行的权限。
chmod +x test.txt 

#文件 test.txt 的所有者分配读,写和执行的权限;
#群组其他用户分配读的权限,不能写或执行;
#其他用户没有任何权限。
chmod u=rwx,g=r,o=- test.txt 

用字母其实也比较方便,虽然看起来有点复杂,但是至少不用自己算。不过我个人喜欢上面的数字,这个看大家喜好啦~如果我们要递归分配一个目录下所有文件,不管是哪种方式加上-R参数即可。

3.3、改变文件所有者与群组

对于那些想使用其他用户甚至是root文件的用户,或者把自己的文件“转让”给其他用户时,那么就必须向“超级大管家”root来通告一声啦,他会使用chown来帮我们,假设此时还有一个bar用户(来自ui组),我们把刚刚创建的test.txt文件让给他:

chown bar:ui test.txt

此时bar心中狂喜,这下foo肯定操作不了啦,此时foo就像啥也没发现一样直接使用rm删掉了,咦?我们是不是漏掉了啥?此时我们退到home,虽然子目录权限变更了,但是父级目录的权限还是foo的呀,那如何让foo彻底失去控制呢?我们直接使用-R递归文件目录:

chown -R bar:ui /home/foo

就好像把房子卖给了bar,此时别说使用cat查看了,就连cd命令都进不去了:
好家伙的,这下次房子都卖了,门都不让进了,有啥办法没,好歹让可怜的foo进个门啊,text.txt文件还是自己创建的呢!当然可以,我们学习了chown和chmod后可以结合一起用呀,大家可以自己尝试一下~(小提示:先使用usermod改变群组,再使用chmod添加文件权限)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值