第五週作業
1、顯示當前系統上root、fedora或user1用戶的默認shell;
[root@STCO6 ~]# grep -E '^(root|fedora|user1)\>' /etc/passwd | cut -d: -f1,7 root:/bin/bash fedora:/bin/bash user1:/bin/bash
2、找出/etc/rc.d/init.d/functions文件中某單詞後面跟一組小括號的行,形如:hello();
[root@STCO6 ~]# grep -E -o "^[_[:alpha:]]+\(\)" /etc/rc.d/init.d/functions fstab_decode_str() checkpid() __readlink() __fgrep() __kill_pids_term_kill_checkpids() __kill_pids_term_kill() __umount_loop() __source_netdevs_fstab() __source_netdevs_mtab() __umount_loopback_loop() __pids_var_run() __pids_pidof() daemon() killproc() pidfileofproc() pidofproc() status() echo_success() echo_failure() echo_passed() echo_warning() update_boot_stage() success() failure() passed() warning() action() action_silent() strstr() confirm() get_numeric_dev() is_ignored_file() is_true() is_false() apply_sysctl() key_is_random() find_crypto_mount_point() init_crypto()
3、使用echo命令輸出一個絕對路徑,使用grep取出其基名;
[root@STCO6 ~]# echo "/home/suyi/test/testA" | grep -E -o "[^/]+/?$" | cut -d"/" -f1 testA
擴展:取出其路徑名
[root@STCO6 ~]# echo "/home/suyi/test/testA" | grep -oP "^.*(?=/)" /home/suyi/test
4、找出ifconfig命令結果中的1-255之間數字;
[root@STCO6 ~]# ifconfig | egrep -o "[1-9]{1,2}|2[0-5]{1,2}" 29 5 3 19 2 16 8 2 3 19 2 16 8 2 255 255 255 255 6 8 20 29 5 3 64 15 1 29 57 17 56 1 252 79 8 24 6 8 31 79 83 31 5 12 7 1 255 6 1 12 8 65 53 6 1
5、挑戰題:寫一個模式,能匹配合理的IP地址;
^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$
6、挑戰題:寫一個模式,能匹配出所有的郵件地址;
^([a-zA-Z0-9_\-\.\+]+)@([a-zA-Z0-9_\-\.]+)\.([a-zA-Z]{2,5})$
7、查找/var目錄下屬主爲root,且屬組爲mail的所有文件或目錄;
[root@STCO6 ~]# find /var -user root -group mail /var/spool/mail
8、查找當前系統上沒有屬主或屬組的文件;
[root@STCO6 ~]# find / -nouser -o -nogroup
進一步:查找當前系統上沒有屬主或屬組,且最近3天內曾被訪問過的文件或目錄;
[root@STCO6 ~]# find / -nouser -o -nogroup -a -atime -3
9、查找/etc目錄下所有用戶都有寫權限的文件;
[root@STCO6 ~]# find /etc -perm /222
10、查找/etc目錄下大於1M,且類型爲普通文件的所有文件;
[root@STCO6 ~]# find /etc -size +1M -type f /etc/gconf/gconf.xml.defaults/%gconf-tree.xml /etc/selinux/targeted/policy/policy.24 /etc/selinux/targeted/modules/active/policy.kern
11、查找/etc/init.d/目錄下,所有用戶都有執行權限,且其它用戶有寫權限的文件;
[root@STCO6 ~]# find /etc/init.d/ -type f -perm -112
12、查找/usr目錄下不屬於root、bin或hadoop的文件;
方式一:
[root@STCO6 ~]# find /usr -not -user root -a -not -user bin -a -not -user hadoop /usr/libexec/abrt-action-install-debuginfo-to-abrt-cache
方式二:
[root@STCO6 ~]# find /usr -not \( -user root -o -user bin -o -user hadoop \) /usr/libexec/abrt-action-install-debuginfo-to-abrt-cache
13、查找/etc/目錄下至少有一類用戶沒有寫權限的文件;
[root@STCO6 ~]# find /etc -not -perm /222
14、查找/etc目錄下最近一週內其內容被修改過,且不屬於root或hadoop的文件;
[root@STCO6 ~]# find /etc/ -type f -ctime -7 -a ! \( -user root -o -user hadoop \)