第五週作業

第五週作業

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 \)


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章