馬哥教育網絡班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 22:51
下一篇 2016-06-26 22:51

相關推薦

  • Blog Day 0:Linux運維學習方法論漫談

    By:Alvin Lin
    No:M30-43
    Date:2018-03-26

    Linux筆記 2018-03-26
  • linux中find命令的那些事

         概述:在介紹find這個強大的文件查找命令前,我們先介紹兩個較簡單的文件查找命令whereis和locate命令,通常我們都是先使用whereis或者是locate檢查,如果真的找不到了,才用find來查找,因為whereis和locate是利用數據庫來查找數據的,速度相當快,節約時間,缺點就是有可…

    Linux干貨 2016-08-18
  • 馬哥教育網絡班22期+第4周課程練習

    1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限。 [root@localhost ~]# cp -r /etc/skel /home/tuser1 [root@localhost ~]# chmod&nb…

    Linux干貨 2016-09-05
  • Linux下find命令的使用

    為什么要使用find命令?     Linux系統中有著成千上萬的文件,如果你想要找到自己想要的文件,一款查找軟件是必不可少的,而locate是根據其生成的數據庫進行查找,雖然速度會略快,但非實時查找,有些新的文件或目錄是匹配不到的,而且locate是模糊匹配,而find命令為實時查找,且為精確匹配,如果你對目錄的權限…

    Linux干貨 2016-08-18
  • 我與Linux的第一次親密接觸

        作為一個新手,經過一周的學習,我對Linux目前有了些許的了解,從Linux的發展史中,開源共享精神深深的感染了我,也使得我對Linux的興趣更加濃厚。對于一個一直翹計算機課的我來說,入門和基礎是一項非常艱巨的任務,初期為了搭建學習的環境,也是費了不小的功夫,相信許多萌也對此有很大的感觸,在這里,我來和大家分享一下如何去構建環境?!?/p>

    Linux干貨 2017-03-26

評論列表(1條)

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

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

欧美性久久久久