N22-妙手-第五周博客作業

1、顯示/boot/grub/grub.conf中以至少一個空白字符開頭的行;

[root@localhost grub]# grep "^[[:space:]]\+" /boot/grub/grub.conf

2、顯示/etc/rc.d/rc.sysinit文件中以#開頭,后面跟至少一個空白字符,而后又有至少一個非空白字符的行;

[root@localhost ~]# grep "^#[[:space:]]\{1,\}[^[:space:]]\+" /etc/rc.d/rc.sysinit

3、打出netstat -tan命令執行結果中以‘LISTEN’,后或跟空白字符結尾的行;

[root@localhost ~]# netstat -tan | grep "LISTEN[[:space:]]*$"

4、添加用戶bash, testbash, basher, nologin (此一個用戶的shell為/sbin/nologin),而后找出當前系統上其用戶名和默認shell相同的用戶的信息;

[root@localhost ~]# useradd bash
[root@localhost ~]# useradd testbash
[root@localhost ~]# useradd basher
[root@localhost ~]# useradd -s /sbin/nologin nologin
[root@localhost ~]# grep -E "^([^:]+\>).*\1$" /etc/passwd
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
bash:x:1000:1000::/home/bash:/bin/bash
nologin:x:1003:1003::/home/nologin:/sbin/nologin

5、顯示當前系統上root、fedora或user1用戶的默認shell;

[root@localhost scripts]# grep "^\(root\|user1\|fedora\)\>" /etc/passwd | cut -d: -f7
/bin/bash
/bin/bash
/bin/bash

6、找出/etc/rc.d/init.d/functions文件中某單詞后面跟一組小括號的行,形如:hello();

[root@localhost ~]# grep -E ".*\>\(\)" /etc/init.d/functions
checkpid() {
__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() {
strstr() {
is_ignored_file() {
is_true() {
is_false() {
apply_sysctl() {

7、使用echo命令輸出一個絕對路徑,使用grep取出其基名;

    擴展:取出其路徑名

[root@localhost ~]# echo /etc/var/log | grep -E -o "[^/]+$" 
log

8、找出ifconfig命令結果中的1-255之間數字;

    兩種方法實現:    

        方法一

[root@localhost ~]# ifconfig | grep -E "\<([0-9]|[1-9][0-9]|2[0-4][0-9]|25[0-5])\>"
        inet 192.168.1.102  netmask 255.255.255.0  broadcast 192.168.1.255
        inet6 fe80::20c:29ff:fe87:765b  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:87:76:5b  txqueuelen 1000  (Ethernet)
        RX packets 3733  bytes 369553 (360.8 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 2311  bytes 448673 (438.1 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

        方法二:

[root@localhost ~]# ifconfig | grep -E "\<[0-9]\>|\<[1-9][0-9]\>|\<[1-2][0-5][0-5]\>"
        inet 192.168.1.102  netmask 255.255.255.0  broadcast 192.168.1.255
        inet6 fe80::20c:29ff:fe87:765b  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:87:76:5b  txqueuelen 1000  (Ethernet)
        RX packets 3458  bytes 343067 (335.0 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 2110  bytes 422465 (412.5 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

9、挑戰題:寫一個模式,能匹配合理的IP地址;

例如匹配192.168.1.105

\<[1-9]\{3\}\.[1-9]\{3\}\.[1-9]\.1[0-9]\{2\}\>

10、挑戰題:寫一個模式,能匹配出所有的郵件地址;

"[[:alnum:]_-]\+@[[:alnum:]]\+\.[[:alpha:]]\+$"

11、查找/var目錄下屬主為root,且屬組為mail的所有文件或目錄;

[root@localhost ~]# find /var -user root -a  -group mail -ls
67150904    0 drwxrwxr-x   2 root     mail           59 Sep 11 08:09 /var/spool/mail

12、查找當前系統上沒有屬主或屬組的文件;

[root@localhost ~]# find / -nouser -a -nogroup -ls
   135    0 drwx------   2 1004     1004           59 Sep 11 09:03 /home/user23
   136    4 -rw-r--r--   1 1004     1004           18 Nov 20  2015 /home/user23/.bash_logout
   137    4 -rw-r--r--   1 1004     1004          193 Nov 20  2015 /home/user23/.bash_profile
   138    4 -rw-r--r--   1 1004     1004          231 Nov 20  2015 /home/user23/.bashrc
find: ‘/proc/2667/task/2667/fd/6’: No such file or directory
find: ‘/proc/2667/task/2667/fdinfo/6’: No such file or directory
find: ‘/proc/2667/fd/6’: No such file or directory
find: ‘/proc/2667/fdinfo/6’: No such file or directory

     進一步:查找當前系統上沒有屬主或屬組,且最近3天內曾被訪問過的文件或目錄;

[root@localhost ~]# find / -nouser -a -nogroup -a -atime -3 -ls
   135    0 drwx------   2 1004     1004           59 Sep 11 09:03 /home/user23
   136    4 -rw-r--r--   1 1004     1004           18 Nov 20  2015 /home/user23/.bash_logout
   137    4 -rw-r--r--   1 1004     1004          193 Nov 20  2015 /home/user23/.bash_profile
   138    4 -rw-r--r--   1 1004     1004          231 Nov 20  2015 /home/user23/.bashrc
find: ‘/proc/2669/task/2669/fd/6’: No such file or directory
find: ‘/proc/2669/task/2669/fdinfo/6’: No such file or directory
find: ‘/proc/2669/fd/6’: No such file or directory
find: ‘/proc/2669/fdinfo/6’: No such file or directory

13、查找/etc目錄下所有用戶都有寫權限的文件;

[root@localhost ~]# find /etc -perm -222 -ls

14、查找/etc目錄下大于1M,且類型為普通文件的所有文件;

[root@localhost ~]# find /etc -type f -a -size +1M -exec ls -lh {} \;
-r--r--r--. 1 root root 6.7M Aug 30 11:12 /etc/udev/hwdb.bin
-rw-r--r--. 1 root root 3.7M Nov 21  2015 /etc/selinux/targeted/policy/policy.29

15、查找/etc/init.d/目錄下,所有用戶都有執行權限,且其它用戶有寫權限的文件;

[root@localhost ~]# find /etc -perm -113 -ls

16、查找/usr目錄下不屬于root、bin或hadoop的文件;

[root@localhost ~]# find /usr -not \( -user root -a -user bin -user hadoop \) -ls

17、查找/etc/目錄下至少有一類用戶沒有寫權限的文件;

[root@localhost scripts]# find /etc -not -perm -222 -ls

18、查找/etc目錄下最近一周內其內容被修改過,且不屬于root或hadoop的文件;

[root@localhost scripts]# find /etc/ -mtime -7 -a -not \( -user root -a -user hadoop \) -exec ls -l {} \;

原創文章,作者:mxb93,如若轉載,請注明出處:http://www.www58058.com/45577

(0)
mxb93mxb93
上一篇 2016-09-19
下一篇 2016-09-19

相關推薦

  • 計算機基礎

    計算機系統 計算機系統由兩大部分組成硬件系統(Hartware)和軟件系統(Software) 硬件系統:主要由中央處理器、存儲器、輸入輸出控制系統和各種外部設備組成。中央處理器是對信息進行高速運算處理的主要部件,其處理速度可達每秒幾億次以上操作。存儲器用于存儲程序、數據和文件,常由快速的主存儲器(容量可達數百兆字節,甚至數G字節)和慢速海量輔助存儲器(容量…

    Linux干貨 2017-05-20
  • linux下的文件查找命令對比(locate,find,grep,sed)

        在linux下,文件系統占據著非常重要的位置,而我們對于文件系統的操作也顯得尤為重要。 如果我們想熟悉的操作文件系統,其中,我們需要對文本的查找,截取等命令需要熟悉的掌握。 這里就不得不說幾個關于文本操作的幾個命令的作用詳細介紹和對比。比如: locate,find ,grep ,sed等。 這里,grep ,…

    Linux干貨 2016-08-15
  • LVM 邏輯卷管理器-增大LV容量

    LVM 邏輯卷管理器-增大LV的容量   步驟: (1)新增一個8e systemID的分區; (2)用pvcreate命令構建PV; (3)用vgextend命令將PV加入vg_1; (4)用lvresize命令將新加入的PV內的PE加入lv_1中; (5)通過resize2fs命令將LV的容量擴充到整個文件系統;   (1)新增一個8…

    Linux干貨 2016-09-19
  • bonding命令

    一、Bonding是什么將多塊網卡綁定同一IP地址對外提供服務,可以實現高可用或者負載均衡。直接給兩塊網卡設置同一IP地址是不可以的。通過bonding,虛擬一塊網卡對外提供連接,物理網卡的被修改為相同的MAC地址。 二、Bonding工作模式Mode 0 (balance-rr)輪轉(Round-robin)策略:從頭到尾順序的在每一個slave接口上面發…

    2017-09-10
  • awk用法一

      gawk程序是Unix中的原始awk程序的GNU版本,它提供了一種編程語言而不只是編輯器命令。在CentOS中awk命令實際上是gawk程序的鏈接文件名。   基本語法:     awk [options] ‘program’ flie1 file2 ……

    Linux干貨 2015-12-24
  • http協議

    Web Service概述 web服務時一種應用程序的服務,它所提供的最主要的信息是一種超文本標記語言(HTML)、多媒體資源(如:視頻、圖片、音樂等)。HTML是一種純文字的文本信息,通過所謂的標簽來規范所要顯示的內容格式,在客戶端通過瀏覽器的形式對HTML及多媒體資源進行解析,然后呈現在終端上。主要由http和https協議實現 http協議概述 HTT…

    Linux干貨 2016-10-28

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-09-19 18:53

    ip地址匹配不對,沒有好好聽咱們的周日的分享吧,老師講過的

欧美性久久久久