Linux基础教程之vim、定时任务、脚本初步应用及详解

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

  ~]#cp  /etc/rc.d/rc.sysinit   /tmp
  在末行模式下输入:%s@^[[:space:]]\+[^[:space:]]@#&@g
    &:匹配模式找到的全部文本
    &=^[[:space:]]\+[^[:space:]]

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

~]#cp /boot/grub/grub.conf /tmp
在末行模式下输入:%s@^[[:space:]]\+@@

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

在末行模式下输入:%s@^#[[:space:]]\+@@g

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

在末行模式下输入:1,3s@^@#

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

在末行模式下输入:%s@\(enabled\|gpgcheck\)=0@\1=1@g
\1是后向引用,就是正则表达式中匹配到的项
\1=enabled或gpgcheck

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

crontab -e  进入编辑界面
00 */4 * * * cp -r /backup/etc-$(date +\%Y\%m\%d\%H\%M)

%前要用转义\

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

crontab -e  进入编辑界面
~】#00 00 * * 2,4,6 cp -r /var/log/messages /backup/messages_logs/messages-$(date +\%Y\%m\%d)

%前要用转义\

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

crontab -e  进入编辑界面
00 */2 * * * cat /proc/meminfo |grep "^S" >> /stats/memory.txt

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

00 9-18/2 * * 1-5 echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间; 并在此目录创建100个空文件:file1-file100。

#!/bin/bash
#
         mkdir /tmp/testdir-$(date +%Y%m%d%H%M%)
                cd /tmp/testdir-$(date +%Y%m%d%H%M%)
        for i in {1..100};do
                mkdir file$i
        done

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

sed -n '2~2p' /etc/passwd |awk -F: '{print $1}'

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

#!/bin/bash
#

    for i in {10..19};do
            if id user$i ;then
                    echo "user$i exists."
            else
                    useradd user$i
                    echo "user$i" | passwd --stdin user$i
            fi
    done

14、在/tmp/创建10个空文件file10-file19; 把file10的属主和属组改为user10,依次类推。”

#!/bin/bash
#
            cd /tmp/
    for i in {10..19};do
            if [ -e file$i ] ;then
                    echo "file$i exists."
                    chown user$i:user$i file$i
            else

                    touch file$i
                    chown user$i:user$i file$i
            fi
    done

相关新闻

历经多年发展,已成为国内好评如潮的Linux云计算运维、SRE、Devops、网络安全、云原生、Go、Python开发专业人才培训机构!