本週做業內容:shell
一、顯示當前系統上root、fedora或user1用戶的默認shell;ruby
答:bash
[root@localhost ~]# cat /etc/passwd|egrep '^(root|fedora|user1)' root:x:0:0:root:/root:/bin/bash [root@localhost ~]#
二、找出/etc/rc.d/init.d/functions文件中某單詞後面跟一組小括號的行,形如:hello();app
答:dom
[root@localhost ~]# cat /etc/rc.d/init.d/functions |egrep "[a-z]+\(\)" 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() { __find_mounts() { __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() { [root@localhost ~]#
三、使用echo命令輸出一個絕對路徑,使用grep取出其基名;ide
擴展:取出其路徑名oop
答:code
[root@localhost ~]# echo /etc/passwd |grep -o "[^/]*$" passwd [root@localhost ~]# echo /etc/passwd |grep -o "/.*/" /etc/ [root@localhost ~]#
四、找出ifconfig命令結果中的1-255之間數字;blog
答:hadoop
[root@localhost ~]# ifconfig | egrep -o "[1-9]{1,2}|2[0-5]{1,2}" 29 29 88 19 2 16 8 2 55 19 2 16 8 2 255 255 255 255 6 8 20 29 29 88 64 15 1 38 91 11 78 8 1 46 61 15 4 4 12 34 4 9 1 1 12 7 1 255 6 1 12 8 65 53 6 1 [root@localhost ~]#
五、挑戰題:寫一個模式,能匹配合理的IP地址;
答:
[root@localhost ~]# ifconfig | egrep -o "(\<[1-9]\>|\<[1-9][0-9]\>|\<[1][0-9][0-9]\>|\<[2][0-4][0-9]\>|\<[2][5][0-5]\>)\.(\<[0-9]\>|\<[1-9][0-9]\>|\<[1][0-9][0-9]\>|\<[2][0-4][0-9]\>|\<[2][5][0-5]\>)\.(\<[0-9]\>|\<[1-9][0-9]\>|\<[1][0-9][0-9]\>|\<[2][0-4][0-9]\>|\<[2][5][0-5]\>).(\<[0-9]\>|\<[1-9][0-9]\>|\<[1][0-9][0-9]\>|\<[2][0-4][0-9]\>|\<[2][5][0-5]\>)" 192.168.2.55 192.168.2.255 255.255.255.0 127.0.0.1 255.0.0.0
六、挑戰題:寫一個模式,能匹配出全部的郵件地址;
答:grep '[[:alnum:]]\+@[[:alnum:]]\+\.[[:alnum:]]\+$'
七、查找/var目錄下屬主爲root,且屬組爲mail的全部文件或目錄;
答:
[root@localhost ~]# find /var -user root -group mail -ls 131378 4 drwxrwxr-x 2 root mail 4096 Aug 8 19:06 /var/spool/mail [root@localhost ~]#
八、查找當前系統上沒有屬主或屬組的文件;
進一步:查找當前系統上沒有屬主或屬組,且最近3天內曾被訪問過的文件或目錄;
答:1,
[root@localhost ~]# find / -nouser -o -nogroup find: `/proc/13265/task/13265/fd/5': No such file or directory find: `/proc/13265/task/13265/fd/5': No such file or directory find: `/proc/13265/task/13265/fdinfo/5': No such file or directory find: `/proc/13265/task/13265/fdinfo/5': No such file or directory find: `/proc/13265/fd/5': No such file or directory find: `/proc/13265/fd/5': No such file or directory find: `/proc/13265/fdinfo/5': No such file or directory find: `/proc/13265/fdinfo/5': No such file or directory [root@localhost ~]#
2,
[root@localhost ~]# find / -nouser -o -nogroup -a -atime 3 find: `/proc/13263/task/13263/fd/5': No such file or directory find: `/proc/13263/task/13263/fd/5': No such file or directory find: `/proc/13263/task/13263/fdinfo/5': No such file or directory find: `/proc/13263/task/13263/fdinfo/5': No such file or directory find: `/proc/13263/fd/5': No such file or directory find: `/proc/13263/fd/5': No such file or directory find: `/proc/13263/fdinfo/5': No such file or directory find: `/proc/13263/fdinfo/5': No such file or directory [root@localhost ~]#
九、查找/etc目錄下全部用戶都有寫權限的文件;
答: find /etc -perm -222 -ls
十、查找/etc目錄下大於1M,且類型爲普通文件的全部文件;
答:find /etc -type f -size +1M -ls
十一、查找/etc/init.d/目錄下,全部用戶都有執行權限,且其它用戶有寫權限的文件;
答:
find /etc/init.d/ -type f -perm -102 -ls
十二、查找/usr目錄下不屬於root、bin或hadoop的文件;
答:
find /usr/ -type f ! \( -user root -o -user bin -o -user hadoop \) -ls
1三、查找/etc/目錄下至少有一類用戶沒有寫權限的文件;
答:
find /etc/ ! -perm +222 -ls
1四、查找/etc目錄下最近一週內其內容被修改過,且不屬於root或hadoop的文件;
答:
find /etc/ -type f -ctime -7 -a ! \( -user root -o -user hadoop \) -ls