从Linux小白到大牛——与狼共舞的日子6

马哥教育网络班21期+第6周课程练习

请详细总结vim编辑器的使用并完成以下练习题


1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;


[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/
[root@localhost ~]# vim /tmp/rc.sysinit
    :%s@^[[:space:]]@#&@g

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;


[root@localhost ~]# cp /boot/grub/grub.conf /tmp/
[root@localhost ~]# vim /tmp/grub.conf 
    :%s@^[[:space:]]\+@@g

3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符


[root@localhost ~]# vim /tmp/rc.sysinit
    :%s@^#[[:space:]]\+@@g

4、为/tmp/grub.conf文件中前三行的行首加#号;


[root@localhost ~]# vim /tmp/grub.conf
    :1,3s@^.@#&@g

5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;


[root@localhost ~]# vim /etc/yum.repos.d/CentOS-Media.repo
    :%s@\(enabled\|gpgcheck\)=0@\1=1@g

6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202


[root@localhost ~]# mkdir /backup
[root@localhost backup]# crontab -e
    0 */4 * * * /bin/cp -a /etc /backup/etc-`date '+\%Y\%m\%d\%H\%M'`

7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402


[root@localhost ~]# mkdir /backup/messages_logs
[root@localhost ~]# crontab -e
    0 0 * * 2,4,6 /bin/cp -a /var/log/messages /backup/messages_logs/messages-`date '+\%Y\%m\%d'`

8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中


[root@localhost ~]# mkdir /stats
[root@localhost ~]# crontab -e
    0 */2 * * * /bin/grep ^S /proc/meminfo >> /stats/memory.txt

9、工作日的工作时间内,每两小时执行一次echo "howdy"


[root@localhost ~]# crontab -e
    0 9-21/2 * * 1-5 /bin/echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间;


[root@localhost ~]# cat date.sh 
#!/bin/bash
#
mkdir /tmp/testdir-`date +%Y%m%d%H%M%S`

11、在此目录创建100个空文件:file1-file100


[root@localhost ~]# cat file.sh 
#!/bin/bash
#
for i in {1..100};do
    if [ -f file$i ];then
        echo "file$i exists."
    else
        touch file$i
        echo "file$i create."
done

12、显示/etc/passwd文件中位于第偶数行的用户的用户名;


[root@localhost ~]# cat username.sh 
#!/bin/bash
#
for i in $(seq 2 2 $[`cat /etc/passwd | wc -l`]);do
    head -$i /etc/passwd | tail -1 | cut -d: -f1
done

13、创建10用户user10-user19;密码同用户名;


[root@localhost ~]# cat user1.sh 
#!/bin/bash
#
for i in {10..19};do
    if ! id user$i &>/dev/null;then
        useradd user$i
        echo user$i | passwd --stdin user$i &>/dev/null
        echo "user$i create."
    else
        echo "user$i exists."
    fi
done

14、在/tmp/创建10个空文件file10-file19;


[root@localhost ~]# cat file1.sh 
#!/bin/bash
#
for i in {10..19};do
    if [ -f /tmp/file$i ];then
        echo "file$i exists."
    else
        touch /tmp/file$i
        echo "file$i create."
    fi
done

15、把file10的属主和属组改为user10,依次类推。


[root@localhost ~]# cat owner.sh 
#!/bin/bash
#
for i in {10..19};do
    if [ -f /tmp/file$i ];then
        ! id user$i &>/dev/null && echo "user$i no exists." || chown $i.$i file$i
        [ $? -eq 0 ] && echo "owner and group is $i"
    else
        echo "file$i no exists."
    fi
done

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

(0)
N21_孤狼N21_孤狼
上一篇 2016-10-31
下一篇 2016-10-31

相关推荐

  • iptables练习

    系统的INPUT和OUTPUT默认策略为DROP; 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服务器仅允许响应报文离开本机; 系统默认策略设定: ~]# iptables -P INPUT DROP ~]# iptables -P OUPUT DROP 网络说明…

    Linux干货 2016-12-27
  • 初识shell脚本编程

    shell的编程三种分类方式介绍,如何使用nano命令编写一个脚本命令,及脚本命令运行的2种方式。bash的配置文件及系统启动时加载配置文件的顺序流程

    2017-12-14
  • 磁盘管理2

        centos6 实现loop 设备和文件关联         dd if=/dev/zero of=/testdir/bigfile bs=1M count=500      &nb…

    Linux干货 2016-09-01
  • 马哥教育网络班22期-第13周博客作业

    第13周博客作业 1、建立samba共享,共享目录为/data,要求:(描述完整的过程)   1)共享名为shared,工作组为zhucke;   2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名; &nb…

    Linux干货 2016-12-26
  • yum仓库配置

    yum仓库搭建 yum客户端在安装之前要在服务器下载相关的源数据缓存在 cachedir=/var/cache/yum/$basearch/$releasever中 gpgcheck=1检查数据包的签名完整性 导入钥匙或gpgcheck=0就不检查否侧安装不了yum 在/etc/yum.conf设置配置文件 在/etc/yum.repos.d中创建一个后缀是…

    2017-12-03
  • 20160804作业

    查出分区空间使用率的最大百分比值 查出用户UID最大值的用户名、UID及shell类型 查出/tmp的权限,以数字方式显示 统计当前连接本机的每个远程主机IP的连接数,并按从大到小排序 利用扩展正则表达式分别表示0-9、10-99、100-199、200-249、250-255        &nb…

    Linux干货 2016-08-08

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-02 14:18

    博客写得非常的好,32个赞,思路清晰,加油!