第六周:vim编辑器和cron计划任务的使用练习

查看vim编辑器的使用介绍另见:http://afterdawn.blog.51cto.com/7503144/1855557

at及cront计划任务介绍见:http://afterdawn.blog.51cto.com/7503144/1864365

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

命令模式下,输入以下内容:
%s@\(^[[:space:]].*\)@#\1@g
或
%s@\(^[[:space:]]\+\)@#\1@g

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

命令模式下,输入:
$s@^[[:space:]]\+@@g

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

命令模式下,输入:
%s@^#[[:space:]]\+@@g

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

命令模式下,输入:
1,3s@\(.*\)@#\1@g
或
1,3s@^@#@g

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

命令模式下,输入:
%s@\(enabled=\|gpgcheck=\)0@\11@g

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

0 */4 * * * /bin/tar -zcvf /backup/etc-$(date +%Y%m%d%H%M).tar.gz /etc/ &>/dev/null

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

0 0 * * 2,4,6 /bin/tar -zxvf /backup/messages_logs/messages-$(date +%Y%m%d).tar.gz /var/log/messages &>/dev/null

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

0 */2 * * * /bin/grep "^S" /proc/meminfo >> /stats/memory.txt

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

0 */2 * * 1-5 /bin/echo ""howdy""

脚本编程练习 
10、创建目录/tmp/testdir-当前日期时间;

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

#!/bin/bash
dir=/tmp/testdir-$(date +%F)
[ ! -d $dir ] && mkdir $dir && cd $dir
for i in $(seq 100); do
        touch file$i
        let i++
done

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

通过脚本实现:

#!/bin/bash
for i in $(seq 2 2 100); do
        sed -n ${i}p /etc/passwd | cut -d: -f1
        let i+=2
done

通过命令实现:

sed -n 'n;p' /etc/passwd | cut -d: -f1

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

#!/bin/bash

for i in $(seq 10 19); do
        useradd user$i
        echo "user$i" | passwd --stdin user$i &>/dev/null
        let i++
done
tail -10 /etc/passwd | cut -d: -f1

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

    

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

#!/bin/bash

for i in $(seq 10 19); do
        useradd user$i
        touch /tmp/file$i
        chown user$i.user$i /tmp/file$i
        echo "user$i" | passwd --stdin user$i &>/dev/null
        let i++
done
tail -10 /etc/passwd | cut -d: -f1

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

(0)
dawningdawning
上一篇 2016-10-26 15:20
下一篇 2016-10-26 18:22

相关推荐

  • inode总结

    inode的介绍以及影响inode号的命令

    2017-11-13
  • BIND(Berkeley Internet Name Domain) is an implementation of the DNS(Domain Name System) (Blob 12)

    正向解析区域、反向解析区域;主/从;子域;基本安全控制;

    2017-11-29
  • 路由以及实验

    路由 路由(routing)是指分组从源到目的地时,决定端到路径的网络范围的进程。路由工作在OSI模型第三层——网络层的数据包转发设备。路由器通过转发数据包来实现网络互连。路由器可以支持多种协议,但绝大多数使用的是TCP/IP协议。路由器通常连接两个或者多个由IP子网或者点到点协议表示的逻辑端口,至少拥有1个物理端口。路由器根据收到数据包中的网络层地址以及路…

    Linux干货 2017-05-11
  • 逻辑卷小结

    逻辑卷 逻辑卷:把不同大小的物理设备,抽象成一个完整的文件系统,方便对物理设备的管理与应用。 其基本步骤为: 1.将指定的设备设置为物理卷     物理卷是指定大小的固定得物理区域 2.用一个或者多个物理卷创建一个卷组 3.创建逻辑卷     在物理卷上创建的逻辑卷由物理区域组成…

    Linux干货 2016-09-01
  • Linux 基础(6)—— 权限

    修改所属人,所属组                文件的 r w x 权限            修改文件的权限chmod          umask &nb…

    2017-07-27
  • OpenSSL用法详解

    OpenSSL用法详解 OpenSSL:        组件:libcrypto,libssl                 openssl &nb…

    Linux干货 2016-09-23