~~

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

  • # who | cut -d" " -f 1 | sort -u

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

  • # id $(who | tail -1 |cut -d" " -f 1)

  • # last | head -1

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

  • # cat /etc/passwd | cut -d":" -f 7 | sort | uniq -c | sort -n | tail -1

  • # cut -d":" -f 7 /etc/passwd | sort | uniq -c | sort -n | tail -1

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

  • # sort -n -t: -k /etc/passwd | tail -10 | tr 'a-z' 'A-Z' > /tmpmaxuser.txt

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

  • # ifconfig | head -2 | tail -1 | cut -d " " -f 10

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

  • # ls /etc/*.conf | tr 'a-z' 'A-Z' > /tmp/etc.conf

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

  • # ls /var | wc -l

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

  • # sort -n -t: -k 3 /etc/group | tail -10 | cut -d ":" -f 1

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

  • # cat /etc/{fstab,issue} >> /tmp/etc.test

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

1> 创建组distro, 其GID为2016;
 #  groupadd -g 2016 distro 

2> 创建用户mandriva, 其ID为1005,基本组为distro;
 #  useradd -u 1005 -g distro mandriva

3> 创建用户mageia, 其ID为1100,家目录为/home/linux;
 #  useradd -u 1100 -d /home/linux mageia 

4> 给用户mageia添加密码,密码为mageedu;
 #  echo mageedu | passwd --stdin mageia

5> 删除mandriva, 但保留其家目录;
 #  userdel mandriva

6> 创建用户slackware, 其ID为2002,其本组为distro, 附加组peguin;
 #  useradd -u 2002 -g distro -G peguin slackware

7> 修改slackware的默认shell为/bin/tcsh;
 #  usermod -s /bin/tcsh slackware

8> 为用户slackware 新增附加组admins;
 #  usermod -G admins slackware

9> 为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天;
 #  passwd -x 180 -n 3 -w 3 slackware 

10> 添加用户openstack, 其ID为3003,基本组为clouds, 附加组为peguin和nova;
 #  useradd openstack -u 3003 -g clouds -G peguin,nova

11> 添加系统用户mysql,要求其shell为/sbin/nologin;
 #  useradd mysql -s /sbin/nologin

12> 使用echo 命令,非交互式为openstack 添加密码;
 #  echo "openstack" | passwd --stdin openstackp

命令详解


cut ,sort ,head ,tail ,uniq

cut
  • -d –delimiter=DELIM    指定分隔符

  • -f –fields=LIST    指定字段    +   #   单个字段    +   #,# 离散字段    +   #-# 连续字段  ######sort

  • -n –mumeric-sort   按数字大小排序

  • -t  –field-separator=SEP   指定分隔符

  • -k –key==KEYDEF    用于排序比较的字段

  • -f –ignore-case    忽略字符大小写

  • -u –unique     重复的行只保留一行;    重复行:连续且相同的行 ######head

  • -#  指定输出前行;默认输出10行 tail

  • -#  指定输出后行,默认输出10行

  • -f  实时显示指定文本末行

uniq  报告可移除重复的行
  • uniq [OPTION]… [INPUT [OUTPUT]]

  • -c –count  显示每行的重复次数

  • -u –unique 仅显示未曾重复过的行

  • -d –repeated   仅显示重复过的行

useradd ,usermod ,passwd

useradd
  • useradd -D 显示创建用户的默认配置

  • useradd -D [options] 修改默认选项的值

  • useradd [options] LOGIN

    • -g –gid 基本组

    • -G –groups 附加组

    • -p –password 设置密码

    • -r –system create a system account.创建系统用户

    • -u –uid UID号

    • -s –shell 用户登录shell

    • -d –home-dir 指定用户家目录路径

    • -m –create-home 创建家用户目录

    • -M –no-create-home 不创建家用户目录

    • -c –command    注释信息

usermod
  • -u –uid UID号

  • -g –gid 基本组

  • -G –groups 附加组

  • -a –append 与-G一起使用,用于为用户追加新的附加组

  • -c –command 修改注释信息

  • -d –home-dir 修改用户家目录;用户原来的文件不会被移除

  • -m –move-home  只能与-d一起使用,用于将原来的家目录移动至新目录

  • -l –login  修改用户名

  • -s –shell  修改用户的默认shell

  • -L –lock 锁定用户密码;即在用户原来的密码字符串之前添加一个"!"

  • -U –unlock 解锁用户密码

userdel
  • -r –remove-home    删除用户时并删除家目录

passwd
  • passwd  [-k]  [-l]  [-u [-f]] [-d] [-e] [-n mindays] [-x maxdays] [-w warndays] [-i inactivedays] [-S] [–stdin] [username]

  • -l –lock   锁定用户

  • -u –unlock 解锁用户

  • -f –force

  • -e –exprie 用户下次登录时更改密码

  • -d –delete 删除用户密码

  • -n –ninmun DAYS        最小使用日期

  • -x –maximun DAYS   最大使用日期

  • -w –warning DAYS   警告日期

  • -i –inactive DAYS  失效日期

  • -S –status 显示用户密码状态

  • –stdin 非交互式管道设置密码
    echo "abcdefg" | passwd --stdin root

原创文章,作者:c_c,如若转载,请注明出处:http://www.178linux.com/65645

(0)
c_cc_c
上一篇 2017-01-03 14:43
下一篇 2017-01-03 21:13

相关推荐

  • N_28正则表达式及vim编辑的一些知识

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 ]# who | sort -nu | cut -d” ” -f1 2、取出最后登录到当前系统的用户的相关信息。 ]# who | tail -1 | cut -d” ” -f1 | id 3、取出当前系统上被用户当作其…

    Linux干货 2017-12-16
  • Linux进程及作业管理总结

    一、简介     在使用Windows操作系统中很多时候需要查看某些程序进程的运行情况,一般来说我们可以打开Windows提供的"任务管理器",然后点击"进程"栏即可查看到当前系统运行的进程列表。例如偶尔出现系统内存、CPU占用过高的时候,我们往往都会查看进程列表,并找到当前占用内存或CPU过高的进…

    Linux干货 2015-10-05
  • 单用户模式破解密码与密码的加密

    当你坐在一台CentOS 6主机前,但是却不知道密码,要怎样破解掉密码进入系统呢? 答案很简单: 1、启动系统,当出现如下界面时,按任意键 2、你会看到这个画面 3、敲击“a”键,执行modifiy the kernel arguments 4、键入“1”键,进入单用户模式 5、至此,你已经成功进入系统,并修改了密码! 是不是觉得Centos6的系统这样安全…

    Linux干货 2016-09-13
  • Linux基础知识之用户和组管理

    系统环境:    该博文以CentOS6.8_x86_64和CentOS7.2_x86_64系统为基础,Xshell5远程登录CentOS6.8和CentOS7.2系统,分别以root身份和sjsir用户身份登录系统。 学习的重要问题: 一、为什么要学习用户和组?    首先Linux区别于其他的系统的最重要的特性就是…

    Linux干货 2016-08-02
  • linux安全机制与加密工具使用

    一、加密需要和安全机制 1.不加密流量的易受攻击性 密码/数据嗅探 数据操作 验证操作 相当于邮寄明信片 2.不安全的传统协议 telnet、FTP、POP3等等;不安全密码http、sendmail、NFS等等;不安全信息Ldap、NIS、rsh等等;不安全验证 3.NIST定义的安全属性:美国国家标准与技术研究院 1) 保密性:  &…

    Linux干货 2016-09-25
  • week4:grep命令正则表达式的应用

    1.复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限;     ~]# cp -r /etc/skel/ /home/tuser1 |chmod -R g-rwx,o-rwx /home/tuser1 2.编辑/etc/group文件,添加组hadoop; &…

    Linux干货 2016-11-23