馬哥教育網絡班20期+第三周課程練習

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

  who | cut -d ' ' -f1 | uniq

 

    who : 顯示當前登錄的用戶及其終端和時間。

    w   : 顯示當前登錄的用戶及其正在做什么。

2、取出最后登錄到當前系統的用戶的相關信息。

  who | tail -1

    

    who 命令可以查看當前登錄的用戶,最后一次登錄的用戶信息顯示在最后一行。

3、取出當前系統上被用戶當作其默認shell的最多的那個shell。

  cat /etc/passwd | cut -d : -f7 | sort | uniq -c | sort -n | tail -1

    第一次sort按字母進行排序,讓相通的shell都排在一起,要不然用uniq -c 時會出現一樣的shell有不同的統       計。

4、將/etc/passwd中的第三個字段數值最大的后10個用戶的信息全部改為大寫后保存至/tmp/maxusers.txt文件中。

  cat /etc/passwd | sort -t : -k 3 -n | tail -10  | tr 'a-z' 'A-Z' > /tmp/maxusers.txt

    sort -t :排序時指定 分隔符 

         -k :指定分隔符后面哪一區域的字符串 來 進行排序

         -n :以數字大小進行排序

    tr  : tr 'SET1' 'SET2'  把字符串1轉換為字符串2

5、取出當前主機的IP地址,提示:對ifconfig命令的結果進行切分。

 ifconfig | grep "^[[:space:]]\+\<inet\>"  |cut -d ' ' -f 10 | head -1

6、列出/etc目錄下所有以.conf結尾的文件的文件名,并將其名字轉換為大寫后保存至/tmp/etc.conf文件中。

 ls /etc/*.conf |cut -d '/' -f 3 | tr 'a-z' 'A-Z' > /tmp/etc.conf

7、顯示/var目錄下一級子目錄或文件的總個數。

  ls -l /var | wc -l

8、取出/etc/group文件中第三個字段數值最小的10個組的名字。

  cat /etc/group | sort -t: -k 3 -n | head -10 | cut -d : -f1

9、將/etc/fstab和/etc/issue文件的內容合并為同一個內容后保存至/tmp/etc.test文件中。

 cat /etc/fstab /etc/issue > /tmp/etc.test

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

    linux 用戶和組管理涉及到四個文件 :

        /etc/passwd :用戶賬號信息

           各字段的含義
            root:x:0:0:root:/root:/bin/bash
            賬戶:密碼占位符:UID:GID:注釋信息:家目錄:用戶默認shell

        /etc/shadow :用戶密碼和賬號設定

            root:$6$VfkLhLFa$va6OlLz/I5w.KdIbHEklKu8xC/iL84MgNcK86GeK769ATv27ngCpa8imV2CDGvY5Ec3bGzftSuLT.jcQB/dZ8.:16882:0:99999:7:::
            用戶名:加密的密碼:最近一次密碼修改的時間:最短密碼使用期限:最長密碼使用期限:密碼過期提前幾天警告:密碼非活動期限:賬號過期期限:保留區域

        /etc/group  :用戶組信息

            adminuser:x:1003:natasha,harry
            組名:組密碼占位符:GID:以逗號分隔屬于此組的用戶列表

        /etc/gshadow:用戶組密碼


    用戶和組管理命令:

        useradd :創建用戶

            -u  : 指定uid

            -g  : 指定基本組

            -G  : 指定附加組

            -s  : 指定shell

            -r  :  創建系統用戶

        groupad :創建組

            -g gid : 指定gid

        passwd  : 更改密碼

            –stdin :可不通過交互方式給用戶改密碼。

        userdel : 刪除用戶

            -r  : 一并刪除用戶和家目錄

        groupdel : 刪除組

        usermod   : usermod [option] username

            -u :更改uid

            -g :更改基本組

            -G :更改附加組,通常與-a 一起使用追加附加組

            -d :修改家目錄位置,加-m 可以把用戶原有文件遷移到新的家目錄中

            -s : 更改shell

        chage : 更改用戶密碼策略   chage [option] username

    (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;

        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 -aG admins slackware

    (9)、為slackware添加密碼,且要求密碼最短使用期限為3天,最長為180天,警告為3天

        [root@black ~]# chage slackware
         Changing the aging information for slackware
         Enter the new value, or press ENTER for the default

	    Minimum Password Age [0]: 3
	    Maximum Password Age [30]: 180
	    Last Password Change (YYYY-MM-DD) [2016-06-26]: 
	    Password Expiration Warning [7]: 3
	    Password Inactive [-1]: 
	    Account Expiration Date (YYYY-MM-DD) [-1]: 
       
        [root@black ~]# echo "redhat" | passwd --stdin slackware
            Changing password for user slackware.
            passwd: all authentication tokens updated successfully.
            
        [root@black ~]# cat /etc/shadow | grep slackware
        slackware:$6$QR4xbLYP$GaujSFJLzIEQv1jw72xYObMAnhV5PrRRNZESHHDc9WcKy8g1/S.Ckh1PCb1eJY6EHGUdM        2XEKRglxAK8B1LL20:16978:3:180:3:::

    (10)、添加用戶openstack,其ID號為3003, 基本組為clouds,附加組為peguin和nova;

        groupadd clouds 
        groupadd nova
        useradd -u 3003 -g clouds -G peguin,nova openstack

    (11)、添加系統用戶mysql,要求其shell為/sbin/nologin;

         useradd -r -s /sbin/nogolin mysql

    (12)、使用echo命令,非交互式為openstack添加密碼。

        echo "redhat" | passwd --stdin openstack

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

(0)
CacheCache
上一篇 2016-06-26
下一篇 2016-06-26

相關推薦

  • redis-cli的一些有趣也很有用的功能

    redis-cli我們最常用的三個參數就是-h、-p、-a選項,分配用來指定連接的redis-server的host、port和登錄密碼。通過redis-cli –help發現,redis-cli還提供了其他很多的參數和功能。 1)-x-x選項從標準輸入(stdin)讀取最后一個參數。 比如從管道中讀取輸入: echo -en &quot…

    Linux干貨 2016-04-13
  • Homework Week-7 RAID及bash編程

    1、創建一個10G分區,并格式為ext4文件系統;    (1) 要求其block大小為2048, 預留空間百分比為2, 卷標為MYDATA, 默認掛載屬性包含acl;    (2) 掛載至/data/mydata目錄,要求掛載時禁止程序自動運行,且不更新文件的訪問時間戳; fdisk /dev/sda n …

    Linux干貨 2016-09-26
  • 內核編譯

    內核編譯 程序包的編譯安裝 ./configure,make,make install./configure檢查編譯環境依賴關系,并設定參數make 執行編譯操作make install 安裝二進制庫文件幫助文檔配置文件 前提:開發環境(開發工具,開發庫),頭文件:/usr/include 開源:源代碼 發行版,就是把源代碼拿過來,組織成程序。  …

    Linux干貨 2016-09-19
  • iptables練習

    系統的INPUT和OUTPUT默認策略為DROP; 1、限制本地主機的web服務器在周一不允許訪問;新請求的速率不能超過100個每秒;web服務器包含了admin字符串的頁面不允許訪問;web服務器僅允許響應報文離開本機; 系統默認策略設定: ~]# iptables -P INPUT DROP ~]# iptables -P OUPUT DROP 網絡說明…

    Linux干貨 2016-12-27
  • M21-陸東貴操作類作業

    1.     設置自己的終端提示符,要求字符終端登錄時: a> 需要帶顏色 b> 需要顯示當前執行到了第幾條命令 c> 顯示當前登錄終端,主機名和當前時間 解答:[root@localhost  13:19:55 37 ~]# PS1="[\[\e[1;31m\]\u@\h&nbs…

    Linux干貨 2016-10-18
  • 正則表達式

      文本處理三劍客 grep:文本過濾 grep,egrep(支持擴展正則表達式),fgrep(不支持正則表達式) grep ?需要查找的字符串 查找的目標文件 -v #取反 -i #忽略大小寫 -n #顯示目標字符串的行號 -c #顯示匹配到的次數 -p #靜默模式 -o #僅顯示匹配到的字符串 -A# #顯示包含關鍵字的后續幾行 -B# #顯示…

    2018-04-06

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-06-29 15:25

    寫的很好,排版還可以在漂亮一些,加油

欧美性久久久久