N25-第15周博客作业

1、总结sed和awk的详细用法;    sed [OPTION]...  'script'  [input-file] ...            script:                地址定界编辑命令                            常用选项:                -n:不输出模式空间中的内容至屏幕;                -e script, --expression=script:多点编辑;                -f  /PATH/TO/SED_SCRIPT_FILE                    每行一个编辑命令;                -r, --regexp-extended:支持使用扩展正则表达式;                -i[SUFFIX], --in-place[=SUFFIX]:直接编辑原文件 ;                            ~]# sed  -e  's@^#[[:space:]]*@@'   -e  '/^UUID/d'  /etc/fstab                        地址定界:                (1) 空地址:对全文进行处理;                (2) 单地址:                    #:指定行;                    /pattern/:被此模式所匹配到的每一行;                (3) 地址范围                    #,#:                    #,+#:                    #,/pat1/                    /pat1/,/pat2/                    $:最后一行;                (4) 步进:~                    1~2:所有奇数行                    2~2:所有偶数行                                编辑命令:                d:删除;                p:显示模式空间中的内容;                a  \text:在行后面追加文本“text”,支持使用\n实现多行追加;                 i  \text:在行前面插入文本“text”,支持使用\n实现多行插入;                 c  \text:把匹配到的行替换为此处指定的文本“text”;                w /PATH/TO/SOMEFILE:保存模式空间匹配到的行至指定的文件中;                r  /PATH/FROM/SOMEFILE:读取指定文件的内容至当前文件被模式匹配到的行后面;文件合并;                =:为模式匹配到的行打印行号;                !:条件取反;                    地址定界!编辑命令;                s///:查找替换,其分隔符可自行指定,常用的有s@@@, s###等;                    替换标记:                        g:全局替换;                        w /PATH/TO/SOMEFILE:将替换成功的结果保存至指定文件中;                        p:显示替换成功的行;2、删除/boot/grub/grub.conf文件中所有行的行首的空白字符;    sed 's/^[[:space:]]//g' /boot/grub/grub.conf3、删除/etc/fstab文件中所有以#开头,后跟至少一个空白字符的行的行首的#和空白字符;    sed 's/^#[[:space:]]\+//' /etc/fstab4、把/etc/fstab文件的奇数行另存为/tmp/fstab.3;    sed 'n;d' /etc/fstab >>/tmp/fstab.35、echo一个文件路径给sed命令,取出其基名;进一步地,取出其路径名;    echo /etc/fstab/ | sed -r 's@^/.*/([^/]+)/?$@\1@g'    echo /etc/fstab/ | sed -r 's@[^/]+/?$@@g'6、统计指定文件中所有行中每个单词出现的次数;    awk '{for(i=1;i<=NF;i++) {word[$i]++}}END{for(i in word) {print i,word[i]}}' /etc/fstab7、统计当前系统上所有tcp连接的各种状态的个数;    netstat -tan|awk '/^tcp\>/{state[$NF]++}END{for(i in state){print i,state[i]}}'8、统计指定的web访问日志中各ip的资源访问次数:    awk '{ip[$1]++}END{for(i in ip) {print i,ip[i]}}' /var/log/httpd/access_log9、写一个脚本:定义一个数组,数组元素为/var/log目录下所有以.log结尾的文件的名字;显示每个文件的行数;    #!/bin/bash    filelist=$(ls /var/log/*.log)    for line in ${filelist[*]};do            echo $line            wc -l ${line}    done    #!/bin/bash    filelist=$(ls /var/log/*.log)    for i in $(seq 0 $[${#filelist[*]}-1]);do            echo ${filelist[$i]}            wc -l ${filelist[$i]}    done10、写一个脚本,能从所有同学中随机挑选一个同学回答问题;进一步地:可接受一个参数,做为要挑选的同学的个数;    #!/bin/bash    #    echo "student Name     student NO"    for i in {1..10};do    stu[$i]=stu_$i    echo "${stu[$i]}             $i"    done    j=$[$RANDOM % 10+1]    echo "Random picked student No:$j"    echo "The student name is :${stu[$j]}"                                可接受一个参数,做为要挑选的同学的个数;    #!/bin/bash    #    read -p "Please Input student Numbers:" num    echo "student Name     student NO"    for ((i=1;i<=$num;i++))do    stu[$i]=stu_$i    echo "${stu[$i]}             $i"    done    j=$[$RANDOM % $num+1]    echo "Random picked student No:$j"    echo "The student name is :${stu[$j]}"11、授权centos用户可以运行fdisk命令完成磁盘管理,以及使用mkfs或mke2fs实现文件系统管理;    vim /etc/sudoers    centos  ALL=(root)      NOPASSWD:/sbin/fdisk,/sbin/mke2fs,/sbin/mkfs12、授权gentoo用户可以运行逻辑卷管理的相关命令;    vim /etc/sudoers    gentoo  ALL=(root)      lvm13、基于pam_time.so模块,限制用户通过sshd服务远程登录只能在工作时间进行;    vim /etc/ssh/sshd_config     UsePAM noUsePAM yes  #开启Pam模块认证    vim /etc/pam.d/sshd    /lib64/security/pam_time.so 确保pam_time.so存在     vim /etc/pam.d/sshd    account    required     pam_time.so    vim /etc/security/time.conf    *;*;*;MoTuWeThFr0900-180014、基于pam_listfile.so模块,定义仅某些用户,或某些组内的用户可登录系统;    [root@localhost ~]# vim /etc/sshd_userlist    root    centos    gentoo    chmod 600 /etc/sshd_userlist    chown root /etc/sshd_userlist    vim /etc/pam.d/sshd     #auth       required     pam_listfile.so item=user sense=allow file=/etc/sshd_userlist onerr=succeed

原创文章,作者:oranix,如若转载,请注明出处:http://www.178linux.com/76620

(0)
oranixoranix
上一篇 2017-05-21
下一篇 2017-05-21

相关推荐

  • FHS文件系统介绍及各目录功能说明

     FHS文件系统介绍及各目录功能说明 M21-陆东贵 FHS简介 Filesystem Hierarchy Standard(文件系统目录标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件。FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录,同时还给出了例外处理…

    Linux干货 2016-10-18
  • 阿里云修改hostname主机名的一点小技巧

    CentOS 7以后修改主机名一般使用: hostnamectl set-hostname newhostname 如果仍然无效,使用vim打开/etc/cloud/cloud.cfg,将 preserve_hostname=fale 改为 preserve_hostname=true 即可。 以上在阿里云ECS上亲测有效,使用了网上查阅…

    Linux干货 2017-01-09
  • find 的使用及练习

    find是个使用频率比较高的命令。常常用它在系统特定目录下,查找具有某种特征【名字类型属主权限等】的文件。find命令的格式: find  [-path ..] -options [-print -exec -ok] path:要查找的目录路径。 ~ 表示$HOME目录 . 表示当前目录 / 表示根目录 -print :表示将结果输出到标准输出-e…

    Linux干货 2017-06-11
  • vim常用快捷键

    1、vim /etc/vimrc进入配置文件 如果不知道vimrc文件在哪,可使用 :scriptnames 来查看 set nu      #行号 set tabstop=4  #一个tab为4个空格长度 set ai  #设置自动缩进 syntax on   #高亮   2、基本 空格键 向右移动一格 x 删除后面…

    2017-09-05
  • 文本处理工具之grep正则表达式

    grep简介 grep 是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。 Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,…

    Linux干货 2016-08-08
  • SSH原理与运用:远程登录

    如果本地用户名与远程用户名一致,登录时可以省略用户名。 1 $ ssh host SSH的默认端口是22,也就是说,你的登录请求会送进远程主机的22端口。使用p参数,可以修改这个端口。 1 $ ssh –p 2222 user@host 上面这条命令表示,ssh直接连接远程主机的2222端口。 三、中间人攻击 SSH之所以能够保证安全,原因在于它…

    Linux干货 2017-08-14