linux的管道命令和用户管理命令

1、列出当前系统上的所有已经登录的用户的用户名

[root@localhost home]# who | cut -d" " -f1 | uniq
root
test
root

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

[root@localhost home]# who | tail -1
root     pts/3        2017-07-16 19:38 (192.168.2.46)

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

[root@localhost home]# cut -d: -f7 /etc/passwd | uniq -c | sort -n | tail -1
     13 /sbin/nologin

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

[root@localhost home]# sort -t: -k3 -n /etc/passwd | tail | tr [a-z] [A-Z] > /tmp/maxusers.txt
[root@localhost home]# cat /tmp/maxusers.txt 
AVAHI-AUTOIPD:X:170:170:AVAHI IPV4LL STACK:/VAR/LIB/AVAHI-AUTOIPD:/SBIN/NOLOGIN
POLKITD:X:997:995:USER FOR POLKITD:/:/SBIN/NOLOGIN
SYSTEMD-NETWORK:X:998:996:SYSTEMD NETWORK MANAGEMENT:/:/SBIN/NOLOGIN
SYSTEMD-BUS-PROXY:X:999:997:SYSTEMD BUS PROXY:/:/SBIN/NOLOGIN
GENTOO:X:1000:1000::/HOME/GENTOO:/BIN/BASH
MAGEIA:X:1100:1100::/HOME/LINUX:/BIN/BASH
SLACKWARE:X:2002:2016::/HOME/SLACKWARE:/BIN/TCSH
TEST:X:4001:1000:SHIJL,HS,110,119:/VAR/TMP/GENTOO:/BIN/BASH
FEDORS:X:4002:4002:FEDORA CORE:/HOME/FEDORS:/BIN/TCSH
TEST2:X:4003:4003::/HOME/TEST2:/BIN/BASH

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

[root@localhost home]# ifconfig | grep inet
        inet 192.168.2.250  netmask 255.255.255.0  broadcast 192.168.2.255
        inet6 fe80::20c:29ff:fe73:6f14  prefixlen 64  scopeid 0x20<link>
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>

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

[root@localhost home]# find /etc/ -name "*.conf" | tr [a-z] [A-Z] > /tmp/etc.conf
[root@localhost home]# cat /tmp/etc.conf
/ETC/RESOLV.CONF
/ETC/PKI/CA-TRUST/CA-LEGACY.CONF
/ETC/YUM/PLUGINCONF.D/FASTESTMIRROR.CONF
/ETC/YUM/PLUGINCONF.D/LANGPACKS.CONF
/ETC/YUM/PROTECTED.D/SYSTEMD.CONF
/ETC/YUM/VERSION-GROUPS.CONF
/ETC/YUM/YUM-CRON-HOURLY.CONF
/ETC/YUM/YUM-CRON.CONF

#由于文件大多,只是截图一部分;

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

[root@localhost ~]# ls /var/ | wc -w
20

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

[root@localhost ~]# sort -t: -k3 -n /etc/group | head | cut -d: -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem

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

[root@localhost ~]# cat /etc/{fstab,issue} > /tmp/etc.test
[root@localhost ~]# cat /tmp/etc.test 

#
# /etc/fstab
# Created by anaconda on Thu Jul  6 13:10:02 2017
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/centos-root /                       xfs     defaults        0 0
UUID=67f1323c-af86-45f5-8538-88e92b7787e8 /boot                   xfs     defaults        0 0
/dev/mapper/centos-home /home                   xfs     defaults        0 0
/dev/mapper/centos-swap swap                    swap    defaults        0 0
\S
Kernel \r on an \m

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

useradd,usermod,userdel,passwd,groupadd,groupmod,groupdel,gpasswd,chfn,  chsh,finger,id,su;

(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添加密码,密为tangkai;

~]#echo "tangkai" | passwd --stdin mageia

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

~]#userdel mandriva

(6)创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;

~]#groupadd peguin
~]#useradd -u 2002 -g distro -G peguin slackware

(7)修改slackware的默认shell为/bin/tcsh;

~]#usermod -s /bin/tcsh slackware

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

~]#groupadd admins
~]#usermod -a -G admins slackware

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

(0)
N27_shijinlongN27_shijinlong
上一篇 2017-07-16 23:15
下一篇 2017-07-17 15:19

相关推荐

  • 文件编辑之神器Sed

    pattern space   //  文本中每行内容都会进入到pattern space中, 如果匹配到了,就会进入到右分支, 如果没有匹配到,则进入左分支。 hold space  //  就是已经被模式匹配到, 并且编辑后保存的内容就是hold space 中. 默认情况下,当没有被匹配之后,没有匹配到…

    Linux干货 2016-08-15
  • linux入门

    基本知识和操作用法。

    Linux干货 2017-11-30
  • PHP的类自动加载机制

    在PHP开发过程中,如果希望从外部引入一个class,通常会使用include和require方法,去把定义这个class的文件包含进来。这个在小规模开发的时候,没什么大问题。但在大型的开发项目中,这么做会产生大量的require或者include方法调用,这样不因降低效率,而且使得代码难以维护,况且require_once的代价很大。 在PHP5之前,各个…

    Linux干货 2015-04-10
  • 第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; 答:#egrp ‘^(root|fedora|user1)’ /etc/passwd | cut -f1,7 -d: 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello(); 答:#egrp -o &…

    Linux干货 2017-02-25
  • heartbeartv2实现lamp高可用-week17

    3、基于heartbeat v2 crm实现HA LAMP组合;要求,部署wordpress,用于编辑的文章中的任何数据在节点切换后都能正常访问; 拓扑: 环境: CentOS6.6NFS: 172.16.0.34 输出mysql数据目录ntp: 172.16.0.31 时间服务器node1: 172.16.0.32 heartbeart+httpd+php…

    Linux干货 2017-05-23
  • Linux文件查找之locate、find详解

     locate命令详解 locate命令其实是find -name的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库文件,这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updat…

    Linux干货 2016-08-16

评论列表(1条)

  • 马哥教育
    马哥教育 2017-07-22 21:42

    非常棒,再接再励。