用户及用户组管理使用的练习

用户及用户组管理使用的练习

1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。

先使用who得出登陆用户,通过uniq去重。

[root@mail ~]# who | grep -E -o "^[[:alnum:]]+"  | uniq 
root

2、取出最后登录到当前系统的用户的相关信息。

思路:首先使用who取得最后系统的登陆用户,然后把结果通过命令过滤得到用户名,最后通过ID命令显示

方法1:
[root@mail ~]# id $( who | tail -n 1 | grep -E -o "^[[:alnum:]]+" )
uid=0(root) gid=0(root) 组=0(root)

方法2:用cut代替grep
[root@mail ~]# id $(who | tail -n 1 | cut -d' ' -f1 )
uid=0(root) gid=0(root) 组=0(root)
[root@mail ~]# 

3、取出当前系统上被用户当作其默认shell的最多的那个shell

思路:先把passwd的shell取出来通过管道送个uniq去重并计算,再通过sort排序,最后用head取出最高计次的结果。

方法1:
[root@mail ~]# grep -E "/*[[:alnum:]]+/*[[:alnum:]]+$" /etc/passwd -o  | uniq -cd | sort | head -n 1
     16 /sbin/nologin
方法2:
用cut替代grep
[root@mail ~]# cut -d: -f7 /etc/passwd  | uniq -cd | sort | head -n 1
     16 /sbin/nologin

4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。

思路:首先用cut命令把1和3列提取出来,通过sort利用分隔符以数字形式排序第2列的内容,再通过tail得到最大数值的用户,最后通过tr命令把小写字母换成大写并重定向/tmp/maxusers

[root@mail ~]# cut -d: -f1,3 /etc/passwd  | sort -t: -k2 -n | tail -n 10 | cut -d: -f1 | tr [a-z] [A-Z] > /tmp/maxusers.txt
[root@mail ~]# cat /tmp/maxusers.txt    //查看结果

5、取出当前主机的IP地址,提示:对ifconfig命令的结果进行切分。

思路:先使用grep过滤不需要的信息,然后通过cut命令进行切分,得出IP

ifconfig | grep "\<inet\>"  | grep "addr:[[:digit:]]*.*" -o | cut -d' ' -f1 | cut -d: -f2

6、列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中。

思路:先找出文件然后通过tr命令转换并重定向文件中

[root@mail ~]# ls /etc/*.conf | tr [a-z] [A-Z] > /tmp/etc.conf
[root@mail ~]# cat /tmp/etc.conf 

7、显示/var目录下一级子目录或文件的总个数。

思路:通过wc统计行即可

[root@mail ~]# ls /var -l | wc -l
19

8、取出/etc/group文件中第三个字段数值最小的10个组的名字。

思路:用cut分割先取出排序内容,通过sort排序最后用head取出前10行即可

[root@mail ~]# cut -d: -f1,3 /etc/group | sort -t: -n -k2 | head 

9、将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。

思路:cat能同时打开多个文件,重定向到文件即可。

[root@mail ~]# cat /etc/fstab /etc/issue > /tmp/etc.test
[root@mail ~]# cat /tmp/etc.test 

10、请总结描述用户和组管理类命令的使用方法并完成以下练习:

  1. 创建组distro,其GID为2016;
[root@mail ~]# groupadd -g 2016 distro
[root@mail ~]# cat /etc/group | grep distro 
distro:x:2016:
  1. 创建用户mandriva, 其ID号为1005;基本组为distro;
[root@mail ~]# useradd -u 1005 -g distro mandriva
[root@mail ~]# id mandriva
uid=1005(mandriva) gid=2016(distro) 组=2016(distro)
  1. 创建用户mageia,其ID号为1100,家目录为/home/linux;
[root@mail ~]# useradd -u 1100 -m -d /home/linux mageia
[root@mail ~]# cat /etc/passwd | grep mageia
mageia:x:1100:1100::/home/linux:/bin/bash
  1. 给用户mageia添加密码,密码为mageedu;
[root@mail ~]# echo "mageedu" | passwd --stdin mageia
更改用户 mageia 的密码 。
passwd: 所有的身份验证令牌已经成功更新。

5.删除mandriva,但保留其家目录;

[root@mail ~]# userdel mandriva 
[root@mail ~]# ls /home/mandriva -d
/home/mandriva
  1. 创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[root@mail ~]# useradd -g distro -G peguin -u 2002 slackware
[root@mail ~]# cat /etc/passwd | grep slackware
slackware:x:2002:2016::/home/slackware:/bin/bash
[root@mail ~]# cat /etc/group | grep peguin
peguin:x:5001:gentoo,slackware
[root@mail ~]# cat /etc/group | grep distro 
distro:x:2016:
  1. 修改slackware的默认shell为/bin/zsh;
[root@mail ~]# usermod -s /bin/zsh slackware
[root@mail ~]# cat /etc/passwd | grep slackware
slackware:x:2002:2016::/home/slackware:/bin/zsh

8.为用户slackware新增附加组admins;

[root@mail ~]# groupadd admins
[root@mail ~]# usermod -G admins slackware
[root@mail ~]# cat /etc/group | grep admins
admins:x:5003:slackware

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/92651

(0)
oneeonee
上一篇 2018-03-18
下一篇 2018-03-18

相关推荐

  • 实现NFS为lamp环境web站点提供共享存储

    1.实验需求 (1)nfs server导出/data/application/web,在目录中提供wordpress; (2)nfs client挂载nfs server导出的文件系统,至/var/www/html; (3)客户端1(lamp)部署wordpress,并让其正常访问,要确保正常发文章,上传图片。 (4)客户端2(lamp),挂载nfs se…

    Linux干货 2017-05-02
  • LNAMP Shell 部署脚本

    LNAMP Shell 部署脚本 学习总结: 这个脚本,早期是出于对个人学习Shell的总结而写,应该有些年头了,目前也在一边学马哥视频的基础上陆续完善,10月初才完成LNAMP环境的分离式部署,并减少整个Shell脚本各部分的依赖关系。 我是网络班13期高级班的学员,因个人做了几年Linux运维,所以目前整个高级班的课程,我是跳着看了集群(LVS + Ke…

    Linux干货 2015-10-27
  • Linux下which、locate、find 命令查找文件

    在Linux下我们经常要查找某个文件,但是又不记得文件位置,可以使用一些命令来搜索,目前接触到的文件命令有以下几个 which 查看可执行文件的位置 locate 基于数据库查找文件位置 find 实时搜索文件 1、 Which   语法:which 可执行二进制文件名称   Which是通过PATH环境变量查找文件的,在PATH 指定的…

    2017-08-14
  • Linux发展史

    独白:    先来说说我对Linux的认识吧,用一个成语形容:狗屁不通,想了一下,文明社会还是和谐点比较好,算是闻所未闻吧。15年初从朋友那得知Linxu,冲着他那十几K的工资还是挺心动的,说实在很仰慕他,有点计算机基础,自学两个月出山,当时月薪8k;而我还是拿着3,4k的工资,也没什么本领,于是找他要了些有关视频资料,也开始了自学之路,…

    Linux干货 2017-04-08
  • 五大主流数据库模型

    导读:无论是关系型数据库还是非关系型数据库,都是某种数据模型的实现。本文将为大家简要介绍5种常见的数据模型,让我们来追本溯源,窥探现在流行的数据库解决方案背后的神秘世界。 什么是数据模型? 访问数据库中的数据取决于数据库实现的数据模型。数据模型会影响客户端通过API对数据的操作。不同的数据模型可能会提供或多或少的功能。一般而言,数据模型不会直接提供过多的功能…

    Linux干货 2015-04-04
  • week4

    一,复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没 有任何访问权限; cp -r /etc/skel/ /home/tuser1 chmod -R go= /home/tuser1/ 二,编辑/etc/group文件,添加组hado…

    Linux干货 2016-11-18