马哥教育网络班20期+第三周博客作业

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

[root@llww3317 ~]# who    #显示当前用户登录信息
root     tty1         2016-06-26 15:58
root     pts/0        2016-06-26 16:07 (192.168.0.108)
[root@llww3317 ~]# who | cut -d' ' -f1    #取出当前用户登录信息的用户名
root
root
[root@llww3317 ~]# who | cut -d' ' -f1|uniq    #对当前用户登录信息的用户名去重
root

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

[root@llww3317 ~]# who
root     tty1         2016-06-26 15:58
root     pts/0        2016-06-26 16:07 (192.168.0.108)
[root@llww3317 ~]# who |tail -n 1    #取当前用户最后登录的信息的一行数据
root     pts/0        2016-06-26 16:07 (192.168.0.108)
[root@llww3317 ~]# who |tail -n 1|cut -d' ' -f1    #取出用户名
root
[root@llww3317 ~]# who |tail -n 1|cut -d' ' -f1|id    #查询用户相关信息
uid=0(root) gid=0(root) 组=0(root) 环境=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023

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

[root@llww3317 ~]# cut -d: -f7 /etc/passwd|uniq -c|sort -n
      1 /bin/bash
      1 /bin/sync
      1 /sbin/halt
      1 /sbin/shutdown
      4 /sbin/nologin
     13 /sbin/nologin
[root@llww3317 ~]# cut -d: -f7 /etc/passwd|uniq -c|sort -n|tail -n 1
     13 /sbin/nologin

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

[root@llww3317 ~]# cat /etc/passwd|sort -n -k 3 -t: |tail -n 10|tr 'a-z' 'A-Z'
FTP:X:14:50:FTP USER:/VAR/FTP:/SBIN/NOLOGIN
TSS:X:59:59:ACCOUNT USED BY THE TROUSERS PACKAGE TO SANDBOX THE TCSD DAEMON:/DEV/NULL:/SBIN/NOLOGIN
SSHD:X:74:74:PRIVILEGE-SEPARATED SSH:/VAR/EMPTY/SSHD:/SBIN/NOLOGIN
DBUS:X:81:81:SYSTEM MESSAGE BUS:/:/SBIN/NOLOGIN
POSTFIX:X:89:89::/VAR/SPOOL/POSTFIX:/SBIN/NOLOGIN
NOBODY:X:99:99:NOBODY:/:/SBIN/NOLOGIN
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
[root@llww3317 ~]# cat /etc/passwd|sort -n -k 3 -t: |tail -n 10|tr 'a-z' 'A-Z' >> /tmp/maxusers.txt

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

[root@llww3317 /]# ip add list
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:a7:04:6b brd ff:ff:ff:ff:ff:ff
    inet 192.168.0.110/24 brd 192.168.0.255 scope global dynamic eno16777736
       valid_lft 77790sec preferred_lft 77790sec
    inet6 fe80::20c:29ff:fea7:46b/64 scope link 
       valid_lft forever preferred_lft forever
[root@llww3317 /]# ip add list|cut -d " " -f6|sort -n -t. -k1




00:00:00:00:00:00
00:0c:29:a7:04:6b
::1/128
fe80::20c:29ff:fea7:46b/64
qdisc
qdisc
127.0.0.1/8
192.168.0.110/24
[root@llww3317 /]# ip add list|cut -d " " -f6|sort -n -t. -k1|tail -n 1
192.168.0.110/24
[root@llww3317 /]# ip add list|cut -d " " -f6|sort -n -t. -k1|tail -n 1|cut -d/ -f1
192.168.0.110

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

[root@llww3317 ~]# mkdir /tmp/etc
[root@llww3317 ~]# find /etc/*.conf|tr 'a-z' 'A-Z'|cut -d/ -f3 >> /tmp/etc/conf
[root@llww3317 ~]# more /tmp/etc/conf 
ASOUND.CONF
DNSMASQ.CONF
DRACUT.CONF
E2FSCK.CONF
HOST.CONF
KDUMP.CONF
KRB5.CONF
LD.SO.CONF
LIBAUDIT.CONF
LIBUSER.CONF
LOCALE.CONF
LOGROTATE.CONF
MAN_DB.CONF
MKE2FS.CONF
NSSWITCH.CONF
RESOLV.CONF
RSYSLOG.CONF
SESTATUS.CONF
SUDO.CONF
SUDO-LDAP.CONF
SYSCTL.CONF

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

[root@llww3317 /]# ls /var |wc -l
20

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

[root@llww3317 /]# cat /etc/group|sort -n  -t: -k3|head -n 10
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
[root@llww3317 /]# cat /etc/group|sort -n  -t: -k3|head -n 10|cut -d: -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem

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

[root@llww3317 /]# cat /etc/fstab /etc/issue >>/tmp/etc/test
[root@llww3317 /]# more /tmp/etc/test

#
# /etc/fstab
# Created by anaconda on Sun Jun 26 15:45:37 2016
#
# 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_llww3317-root /                       xfs     defaults        0 0
UUID=8e1071af-f465-40a6-945a-eaf70eff0b05 /boot                   xfs     defaults        0 0
/dev/mapper/centos_llww3317-swap swap                    swap    defaults        0 0
\S
Kernel \r on an \m

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

    

(1)、创建组distro,其GID为2016

[root@llww3317 /]# groupadd distro -g 2016

    

(2)、创建用户mandriva,其ID号为1005;基本组为distro;

[root@llww3317 /]# useradd mandriva -u 1005 -g distro

    

(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;

[root@llww3317 /]# useradd mageia -u 1100 -d /home/linux

    

(4)、给用户mageia添加密码,密码为mageedu;

[root@llww3317 /]# echo "mageedu"|passwd --stdin mageia

    

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

[root@llww3317 /]# userdel mandriva

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

[root@llww3317 /]# groupadd peguin
[root@llww3317 /]# useradd slackware -u 2002 -g distro -G peguin

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

[root@llww3317 /]# usermod slackware -s /bin/tcsh

    

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

[root@llww3317 /]# usermod slackware -G admins

     

(9)、为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天;

选项:
  -d, --lastday 最近日期        将最近一次密码设置时间设为“最近日期”
  -E, --expiredate 过期日期     将帐户过期时间设为“过期日期”
  -h, --help                    显示此帮助信息并推出
  -I, --inactive INACITVE       过期 INACTIVE 天数后,设定密码为失效状态
  -l, --list                    显示帐户年龄信息
  -m, --mindays 最小天数        将两次改变密码之间相距的最小天数设为“最小天数”
  -M, --maxdays 最大天数        将两次改变密码之间相距的最大天数设为“最大天数”
  -R, --root CHROOT_DIR         chroot 到的目录
  -W, --warndays 警告天数       将过期警告天数设为“警告天数”

[root@llww3317 /]# echo "123456" |passwd --stdin slackware && chage -W 3 -E 180 -I 3 slackware
更改用户 slackware 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[root@llww3317 /]# chage -l slackware
最近一次密码修改时间                                    :6月 26, 2016
密码过期时间                                    :从不
密码失效时间                                    :从不
帐户过期时间                                            :6月 30, 1970
两次改变密码之间相距的最小天数          :0
两次改变密码之间相距的最大天数          :99999
在密码过期之前警告的天数        :3

CentOS7不知道怎么的,过期时间设置无效果

    

(10)、添加用户openstack,其ID号为3003,基本组为clouds,附加组为peguin和nova

[root@llww3317 /]# useradd openstack -u 3003 -g clouds -G peguin,nova

    

(11)、添加系统用户mysql,要求其shell为/sbin/nologin

[root@llww3317 /]# useradd mysql -u 499 -s /sbin/nologin

    

(12)、使用echo命令,非交互式为openstack添加密码

[root@llww3317 /]# echo "openstack"|passwd --stdin openstack

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

(1)
laiwen2007laiwen2007
上一篇 2016-06-26
下一篇 2016-06-26

相关推荐

  • vsftpd

    文件服务: 安装开启服务前先关闭selinux,清空iptables策略。避免不必要的麻烦,服务开启后,配置一切正常有需要再根据情况开启。 ftp:应用层,C/S,跨主机的文件共享服务;file transfer protocol nfs,cifs:文件系统接口,网络文件系统;     nfs:network&nbsp…

    Linux干货 2016-11-01
  • SElinux管理

                                                      &nbsp…

    系统运维 2016-09-26
  • python面向对象第二周魔术方法详解

    魔法方法及其使用__开头和结束的方法,定义外部没有办法直接调用,但会有影响使用运算符号的魔法方法, + ,-,*,/,%,//,**, __add__,__sub__,__mul__,__truediv__,__mod__,__floordiv__,__pow__,__divmod__(?),系统内部对于数值型,字符串型,容器内型都定义了其中部分或者全部的运…

    Linux干货 2017-11-22
  • MySQL慢日志监控脚本实例剖析

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1577326        公司线上的 MySQL 慢日志,之前一直没有做好监控。趁着上周空闲,我就把监控脚本写了下,…

    Linux干货 2016-08-15
  • ☞文件服务器 – vsftpd

    文件服务器 – vsftpd 概述 FTP协议 vsftpd的配置文件 vsftpd + pam + file_db + virtual_vsftp_user vsftpd + pam + mysql + virtual_vsftp_user 登录时错误类型 总结 文件服务器是一种专供其他电脑访问文件和存储的程序。文件服务器通常比一般的个人电脑拥…

    Linux干货 2016-10-15
  • M22 使用非对称密钥实现ssh自动登陆

    一 实验目的 一般在用户使用ssh客户端登陆ssh服务器时需要使用用户名和密码,本实验使用非对称加密的方式实现了无密码登陆ssh服务器。 二 实验流程  、 1 在客户端生成非对称密钥对 2 将非对称密钥中的公钥发送给ssh服务器端相应的帐号 3 当客户端通过ssh协议与服务器端发起连接时,客户端将私钥加密过的签名发送给服务器端,服务器端使用客户端…

    2017-04-13

评论列表(1条)

  • 马哥教育
    马哥教育 2016-06-29 15:32

    写的很好,排版也很棒,加油