第五週做業

本週做業內容: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

   wKioL1fLm-yBtKHbAAAuu96XOVk546.png

[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

相關文章
相關標籤/搜索