1、列出當前系統上所有已經登錄的用戶的用戶名,注意:同一個用戶登錄多次,則只顯示一次即可。 [root@zabbix ~]# who|awk '{print $1}'|sort| uniq 2、取出最后登錄到當前系統的用戶的相關信息。 [root@zabbix ~]# last [root@zabbix ~]# last|grep -v '^$'|awk '{print $1}'|sort|uniq 3、取出當前系統上被用戶當作其默認shell的最多的那個shell。 [root@zabbix ~]# cat /etc/passwd|awk -F':' '{print $7}'|sort|uniq -c|sort -nr|head -1|awk '{print $2}' 4、將/etc/passwd中的第三個字段數值最大的后10個用戶的信息全部改為大寫后保存至/tmp/maxusers.txt文件中。 USERS=$(cat /etc/passwd |awk -F':' '{print $1}'|sort -n|tail -10) [root@zabbix ~]# for user in $USERS;do echo $(grep "$user:" /etc/passwd |tr a-z A-Z) >> /tmp/maxusers.txt;done 5、取出當前主機的IP地址,提示:對ifconfig命令的結果進行切分。 [root@zabbix ~]# ifconfig|grep netmask|awk '{print $2}' 6、列出/etc目錄下所有以.conf結尾的文件的文件名,并將其名字轉換為大寫后保存至/tmp/etc.conf文件中。 [root@zabbix ~]# ls /etc|grep .*\.conf$ > /tmp/etc.conf [root@zabbix ~]# sed -i 's/[a-z]/\U&/g' /tmp/etc.conf 7、顯示/var目錄下一級子目錄或文件的總個數。 [root@zabbix ~]# ll /var |wc -l 8、取出/etc/group文件中第三個字段數值最小的10個組的名字。 [root@zabbix ~]# cat /etc/group|awk -F':' '{print $3,$1}'|sort -n|head -10|awk '{print $2}' 9、將/etc/fstab和/etc/issue文件的內容合并為同一個內容后保存至/tmp/etc.test文件中。 [root@zabbix ~]# cat /etc/fstab /etc/issue > /tmp/etc.test 10、請總結描述用戶和組管理類命令的使用方法并完成以下練習: 用戶管理類命令: (1)useradd:創建用戶 用法:useradd [options] USERNAME options: -m:創建用戶家目錄; -M:不創建用戶家目錄; -r:指定創建的用戶為系統用戶; -s <SHELL>:指定創建的用戶使用指定的shell; -u <UID>:指定創建的用戶的UID; -U:創建用戶的同時創建同名組; -g <GID|GROUPNAME>:指定創建的用戶所屬的基本組; -G <GROUPS>:指定創建的用戶所屬的附加組; -p <PASSWORD>:設置創建用戶的密碼(加密); (2)userdel:刪除用戶 用法:userdel [options] USERNAME options: -r:刪除用戶,同時刪除用戶家目錄及相關郵件; -f:強制執行刪除用戶行為; (3)usermod:修改賬號屬性 用法:usermode [options] USERNAME options: -c:修改指定賬號的聲明信息; -d <HOME_DIR>:修改指定賬號的家目錄; -g <GROUP>:修改指定賬號所屬的基本組; -G <GROUPS>:修改指定賬號所屬的附加組;如果GROUPS為空;則表示刪除該賬號的附加組信息(沒有附加組); -a -G <NewGroups>:新增指定賬號所屬的附加組信息; -l <NewUSERNAME>:修改指定賬號名為NewUSERNAME; -p <PASSWORD>:修改指定賬號的密碼; -s <SHELL>:修改指定賬號使用的shell; -u <UID>:修改指定賬號的UID; -U:解鎖賬號; (4)passwd:設置或修改用戶密碼 用法:passwd USERNAME passwd [options] USERNAME options: -d:刪除指定賬號密碼; -l:鎖定指定賬號密碼; -u:解鎖指定賬號密碼; -e:設置指定賬號密碼過期; -x:設置指定賬號密碼的最大可用天數; -n:設置指定賬號密碼的最小可用天數; -w:設置指定賬號收到密碼過期通知的天數; -i:設置指定賬號密碼過期后,賬號不可用的天數; -S:顯示指定賬號的密碼狀態; -f:強制執行; 特殊用法: #echo PASSWORD|passwd --stdin USERNAME 設置用戶密碼;只需執行一次即可; 備注:passwd命令需要用戶具有root權限; 組管理類命令: (5)groupadd:創建組 用法:groupadd [options] GROUPNAME options: -g <GID>:指定創建的組的GID; -o:指定創建的組可以使用重復的GID; -p <PASSWORD>:指定創建的組的加密密碼; -r:指定創建的組為系統組; -f:強制執行; (6)groupdel:刪除組 用法:groupdel [options] GROUPNAME options通常不使用 (7)groupmod:修改組 用法:groupmod [options] GROUPNAME options: -g <GID>:修改指定組的GID; -n <New_GRPNAME>:修改指定組的組名為New_GRPNAME; -p <PASSWORD>:修改指定組的密碼; (1)、創建組distro,其GID為2016; [root@zabbix ~]# groupadd -g 2016 distro (2)、創建用戶mandriva, 其ID號為1005;基本組為distro; [root@zabbix ~]# useradd -u 1005 -g distro mandriva (3)、創建用戶mageia,其ID號為1100,家目錄為/home/linux; [root@zabbix ~]# useradd -u 1100 -d /home/linux mageia (4)、給用戶mageia添加密碼,密碼為mageedu; [root@zabbix ~]# echo mageedu|passwd --stdin mageia (5)、刪除mandriva,但保留其家目錄; [root@zabbix ~]# userdel mandriva (6)、創建用戶slackware,其ID號為2002,基本組為distro,附加組peguin; [root@zabbix ~]# groupadd peguin [root@zabbix ~]# useradd -u 2002 -g distro -G peguin slackware (7)、修改slackware的默認shell為/bin/tcsh; [root@zabbix ~]# usermod -s /bin/tcsh slackware (8)、為用戶slackware新增附加組admins; [root@zabbix ~]# groupadd admins [root@zabbix ~]# usermod -a -G admins slackware (9)、為slackware添加密碼,且要求密碼最短使用期限為3天,最長為180天,警告為3天; [root@zabbix ~]# echo mageedu|passwd -x 180 -n 3 -w 3 slackware (10)、添加用戶openstack,其ID號為3003, 基本組為clouds,附加組為peguin和nova; [root@zabbix ~]# useradd -u 3003 -g clouds -G peguin,nova openstack (11)、添加系統用戶mysql,要求其shell為/sbin/nologin; [root@zabbix ~]# useradd -r -s /sbin/nologin mysql (12)、使用echo命令,非交互式為openstack添加密碼。 [root@zabbix ~]# echo mageedu|passwd --stdin openstack
原創文章,作者:devon,如若轉載,請注明出處:http://www.www58058.com/39426
作業與題目最好分開寫,這樣更簡潔,另可以在上述作業可以列舉一下平時該命令使用的例子做以補充。加油?。。?!