linux篩選數據和用戶基本操作

linux篩選數據的基本操作

  • 列出當前系統上所有已經登錄的用戶的用戶名,注意:同一個用戶登錄多次,則只顯示一次即可。

      [root@localhost script]# who
      chenjianhang tty1         2016-10-08 07:51
      root     tty2         2016-10-08 07:51
      root     pts/1        2016-10-08 02:58 (192.168.17.1)
      [root@localhost script]# who | grep -o "^[^[:space:]]*\>" | uniq
      chenjianhang
      root
      [root@localhost script]#
  • 取出最后登錄到當前系統的用戶的相關信息。

      [root@localhost ~]# last -1
      root     pts/1        192.168.17.1     Sat Oct 15 22:39   still logged in   
    
      wtmp begins Thu Dec  3 15:53:02 2015
      [root@localhost ~]#
  • 取出當前系統上被用戶當作其默認shell的最多的那個shell。

      [root@localhost ~]# cat /etc/passwd | cut -d: -f7 | grep ".*sh" | uniq -c
            1 /bin/bash
            1 /sbin/shutdown
            3 /bin/bash
            1 /bin/tcsh
            1 /bin/csh
            7 /bin/bash
      [root@localhost ~]# cat /etc/passwd | cut -d: -f7 | grep ".*sh" | uniq -c | tail -1
            7 /bin/bash
      [root@localhost ~]#
  • 將/etc/passwd中的第三個字段數值最大的后10個用戶的信息全部改為大寫后保存至/tmp/maxusers.txt文件中。

      [root@localhost ~]# cat /etc/passwd | sort  -nk 3 -t : | tail -10 | tr [a-z] [A-Z] >/tmp/maxusers.txt
      [root@localhost ~]# cat /tmp/maxusers.txt
      DOCKER:X:504:504::/HOME/DOCKER:/BIN/CSH
      OPENSTACK:X:3000:3000:COMMENT IMFOTMATION:/HOME/OPENSTACK:/BIN/BASH
      UBUNTE:X:3001:3001:COMMENT IMFOTMATION:/HOME/UBUNTE:/BIN/BASH
      MARIADB:X:3002:162::/HOME/MARIADB:/SBIN/NOLOGIN
      FEDORA:X:3003:3003::/USERS/FEDORA:/BIN/BASH
      WWW:X:3004:3004::/USERS/WWW:/BIN/BASH
      NEWUSERNAME:X:3005:3005::/HOME/NEWUSERNAME:/BIN/BASH
      ROOTKIT:X:3006:3006::/HOME/ROOTKIT:/BIN/BASH
      CHROOT:X:3007:3007::/BIN/CHROOT:/BIN/BASH
      NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
      [root@localhost ~]#
  • 取出當前主機的IP地址,提示:對ifconfig命令的結果進行切分。

      [root@localhost ~]# ifconfig
      eth0      Link encap:Ethernet  HWaddr 00:0C:29:32:B0:C8  
                inet addr:192.168.17.128  Bcast:192.168.17.255  Mask:255.255.255.0
                inet6 addr: fe80::20c:29ff:fe32:b0c8/64 Scope:Link
                UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
                RX packets:4079 errors:0 dropped:0 overruns:0 frame:0
                TX packets:3539 errors:0 dropped:0 overruns:0 carrier:0
                collisions:0 txqueuelen:1000 
                RX bytes:449857 (439.3 KiB)  TX bytes:520996 (508.7 KiB)
                Interrupt:67 Base address:0x2024 
    
      lo        Link encap:Local Loopback  
                inet addr:127.0.0.1  Mask:255.0.0.0
                inet6 addr: ::1/128 Scope:Host
                UP LOOPBACK RUNNING  MTU:16436  Metric:1
                RX packets:1565 errors:0 dropped:0 overruns:0 frame:0
                TX packets:1565 errors:0 dropped:0 overruns:0 carrier:0
                collisions:0 txqueuelen:0 
                RX bytes:3688919 (3.5 MiB)  TX bytes:3688919 (3.5 MiB)
    
      [root@localhost ~]# ifconfig | grep "inet addr" | cut -d":" -f 2 | cut -d" " -f 1
      192.168.17.128
      127.0.0.1
      [root@localhost ~]#
  • 列出/etc目錄下所有以.conf結尾的文件的文件名,并將其名字轉換為大寫后保存至/tmp/etc.conf文件中。

      [root@localhost ~]# ls /etc/*.conf | cut -d"/" -f 3 | tr [a-z] [A-Z] > /tmp/etc.test
      [root@localhost ~]# cat /tmp/etc.test 
      AUTOFS_LDAP_AUTH.CONF
      CDRECORD.CONF
      CONMAN.CONF
      DHCP6C.CONF
      DNSMASQ.CONF
      ESD.CONF
      GPM-ROOT.CONF
      GRUB.CONF
      GSSAPI_MECH.CONF
      HOST.CONF
      IDMAPD.CONF
      INITLOG.CONF
      JWHOIS.CONF
      KRB5.CONF
      LDAP.CONF
      LD.SO.CONF
      LFTP.CONF
      LIBAUDIT.CONF
      LIBUSER.CONF
      LOGROTATE.CONF
      LTRACE.CONF
      MKE2FS.CONF
      MODPROBE.CONF
      MTOOLS.CONF
      MULTIPATH.CONF
      NSCD.CONF
      NSSWITCH.CONF
      NTP.CONF
      ODDJOBD.CONF
      PAM_SMB.CONF
      PRELINK.CONF
      READER.CONF
      RESOLV.CONF
      SCROLLKEEPER.CONF
      SESTATUS.CONF
      SMARTD.CONF
      SYSCTL.CONF
      SYSLOG.CONF
      TPVMLP.CONF
      UPDATEDB.CONF
      WARNQUOTA.CONF
      YP.CONF
      YUM.CONF
      [root@localhost ~]#
  • 顯示/var目錄下一級子目錄或文件的總個數。

      [root@localhost ~]# ll /var
      total 180
      -rw-r--r--  1 root root    0 Sep 25 18:38 1text2x
      -rw-r--r--  1 root root    0 Sep 25 18:38 1text2x2
      -rw-r--r--  1 root root    0 Sep 25 18:38 1text2x-2
      drwxr-xr-x  2 root root 4096 Dec  3  2015 account
      drwxr-xr-x 10 root root 4096 Dec  3  2015 cache
      drwxr-xr-x  2 root root 4096 Feb 23  2012 cvs
      drwxr-xr-x  3 root root 4096 Dec  3  2015 db
      drwxr-xr-x  3 root root 4096 Dec  3  2015 empty
      drwxr-xr-x  2 root root 4096 May 11  2011 games
      drwxrwx--T  2 root gdm  4096 Oct 15 22:24 gdm
      drwxr-xr-x 23 root root 4096 Dec  3  2015 lib
      drwxr-xr-x  2 root root 4096 May 11  2011 local
      drwxrwxr-x  6 root lock 4096 Oct 16 08:23 lock
      drwxr-xr-x 12 root root 4096 Oct 16 04:02 log
      lrwxrwxrwx  1 root root   10 Dec  3  2015 mail -> spool/mail
      drwxr-xr-x  2 root root 4096 May 11  2011 nis
      drwxr-xr-x  2 root root 4096 May 11  2011 opt
      -rw-r--r--  1 root root    0 Sep 25 18:42 ppasswd
      drwxr-xr-x  2 root root 4096 May 11  2011 preserve
      drwxr-xr-x  2 root root 4096 Sep 11  2012 racoon
      drwxr-xr-x 18 root root 4096 Oct 16 07:25 run
      drwxr-xr-x 11 root root 4096 Dec  3  2015 spool
      drwxrwxrwt  3 root root 4096 Sep 22 08:03 tmp
      drwxr-xr-x  6 root root 4096 Dec  3  2015 www
      drwxr-xr-x  3 root root 4096 Dec  3  2015 yp
      [root@localhost ~]# ll /var | wc -l
      26
      [root@localhost ~]#
  • 取出/etc/group文件中第三個字段數值最小的10個組的名字。

      [root@localhost ~]# cat /etc/group | sort -n -t ":" -k 3 | head -10 | cut -d ":" -f 1
      root
      bin
      daemon
      sys
      adm
      tty
      disk
      lp
      mem
      kmem
      [root@localhost ~]#
  • 將/etc/fstab和/etc/issue文件的內容合并為同一個內容后保存至/tmp/etc.test文件中。

      [root@localhost ~]# cat /etc/fstab /etc/issue > /tmp/etc.test
      [root@localhost ~]# cat /tmp/etc/test
      cat: /tmp/etc/test: No such file or directory
      [root@localhost ~]# cat /tmp/etc.test
      LABEL=/                 /                       ext3    defaults        1 1
      LABEL=/boot             /boot                   ext3    defaults        1 2
      tmpfs                   /dev/shm                tmpfs   defaults        0 0
      devpts                  /dev/pts                devpts  gid=5,mode=620  0 0
      sysfs                   /sys                    sysfs   defaults        0 0
      proc                    /proc                   proc    defaults        0 0
      LABEL=SWAP-sda3         swap                    swap    defaults        0 0
      CentOS release 5.11 (Final)
      Kernel \r on an \m
    
      [root@localhost ~]#

請總結描述用戶和組管理類命令的使用方法并完成以下練習

  • 創建組distro,其GID為2016;

      [root@localhost ~]# groupadd -g 2016 distro
  • 創建用戶mandriva, 其ID號為1005;基本組為distro;

      [root@localhost ~]# adduser -u 1005 -g distro mandriva
  • 創建用戶mageia,其ID號為1100,家目錄為/home/linux;

      [root@localhost ~]# adduser -u 1100 -d /home/linux mageia
  • 給用戶mageia添加密碼,密碼為mageedu;

      [root@localhost ~]# passwd mageia
      Changing password for user mageia.
      New UNIX password: 
      BAD PASSWORD: it is based on a dictionary word
      Retype new UNIX password: 
      passwd: all authentication tokens updated successfully.
      [root@localhost ~]#
  • 刪除mandriva,但保留其家目錄;

      [root@localhost ~]# userdel mandriva
  • 創建用戶slackware,其ID號為2002,基本組為distro,附加組peguin;

      [root@localhost ~]# useradd -u 2002 -g distro -G peguin
  • 修改slackware的默認shell為/bin/tcsh;

      [root@localhost ~]# usermod --shell /bash/tcsh slackware
  • 為用戶slackware新增附加組admins;

      [root@localhost ~]# usermod -G admins slackware
  • 為slackware添加密碼,且要求密碼最短使用期限為3天,最長為180天,警告為3天;

      [root@localhost ~]# passwd -n 3 -x 180 -w 3 slackware
      Adjusting aging data for user slackware.
      passwd: Success
      [root@localhost ~]#
  • 添加用戶openstack,其ID號為3003, 基本組為clouds,附加組為peguin和nova;

      [root@localhost ~]# useradd -u 3003 -g clouds -G peguin,nova openstack
  • 添加系統用戶mysql,要求其shell為/sbin/nologin;

      [root@localhost ~]# adduser --shell /sbin/nologin mysql
  • 使用echo命令,非交互式為openstack添加密碼。

      [root@localhost ~]# echo "openstack" | passwd --stdin openstack
      Changing password for user openstack.
      passwd: all authentication tokens updated successfully.
      [root@localhost ~]#

原創文章,作者:Theo,如若轉載,請注明出處:http://www.www58058.com/52310

(0)
TheoTheo
上一篇 2016-10-16 22:31
下一篇 2016-10-17 00:26

相關推薦

  • MySQL流程函數

    MySQL流程函數 IF(value,x y) 如果value是真,返回x,否則返回y MariaDB [learn]> INSERT INTO salary(sal) VALUES (1000),(2000),(3000),(4000),(5000),(6000),(NULL); Query OK, 7 rows affected (0.06 sec…

    Linux干貨 2017-05-02
  • OPENSSL加密技術及私有CA的搭建

    加密方式有對稱加密 非對稱加密 單向加密 對稱加密:     加密和加密都用同一個對稱密鑰,但是,這種加密方法存在一定問題,就是密鑰傳輸時,容易被盜竊。還有密鑰管理困難,對稱加密的方法:DES、AES、Blowfish、Twofish、IDEA、RC6、CAST5。   非對稱加密: 公鑰…

    Linux干貨 2015-08-17
  • 面授20-1班 0805課間練習與課后作業

    課間練習 第一階段 新學的命令文本命令cat tac rev more less head tail cut paste wc sort dif patch 1 、找出ifconfig 命令結果中本機的所有IPv4 地址 [root@IP70-CentOS7 ~]# >>ifconfig | tr&nbsp…

    Linux干貨 2016-08-07
  • N26_第一周作業

    一、描述計算機的組成及其功能。 計算機系統:是由硬件(Hardware)系統和軟件(Software)系統兩大部分構成。 1、硬件系統: 1)控制器(Control):是整個計算機的中樞神經,其功能是對程序規定的控制信息進行解釋,根據其要求進行控制,調度程序、數據、地址,協調計算機各部分工作及內存與外設的訪問等。2)運算器(Datapath):運算器的功能是…

    2017-02-20
  • lamp架構實現論壇架構及壓力測試

    練習:分別使用CentOS 7和CentOS 6實現以下任務 (1) 配置四個基于名稱的虛擬主機;   (a) discuzX   (b) wordpress   (c) drupal   (d) phpMyAdmin,此虛擬主機僅支持https協議; (2) 對phpMyAdmin首頁做壓力測試   分別給…

    Linux干貨 2016-10-17
  • Linux下的I/O重定向與管道

    一、I/O設備     Linux中,對系統進行操作時,就需要I/O設備與系統產生交互,同時會產生三種數據,標準輸入(0)、標準輸出(1)、標準錯誤(2)。其中標準輸入(stdin)默認接受來自鍵盤的輸入,標準輸出(stdout)和標準錯誤(stderr)默認向終端窗口輸出,改變默認輸出和出入的位置,就是I/O重定向。 二、輸出重定向到文…

    Linux干貨 2016-08-04

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-10-20 19:42

    這套題基本涵蓋了Linux系統中全部的用戶管理情景,掌握的不錯,繼續加油。

欧美性久久久久