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

 

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

(6)
N24_yeziN24_yezi
上一篇 2016-12-04 22:50
下一篇 2016-12-05 00:19

相关推荐

  • linux基本命令的使用

      1>    查看当前终端名:tty 或who am i       查看当前所有登录的终端信息:who       查看当前所有登录的终端的详细信息 w 2> 编辑器    …

    2017-07-15
  • 项目实践==虚拟主机及SSL通信(Blog 14)

    httpd-2.4及httpd-2.4实现

    2017-12-02
  • N25-第13周博客作业

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

    Linux干货 2017-05-21
  • rsync+inotify实现数据实时同步备份

    定时备份和实时备份        说到备份,无疑于定时备份和实时同步备份。定时备份可以通过脚本或者Crontab来实现,而实时同步备份可以通过某些接口监控文件的各种变化情况来实现的(比如内核接口inotify);通过对比可以发现对数据信息要求高的环境使用实时同步备份可以更好更有利的保护数据的安全性。 软件介绍之rsyn…

    Linux干货 2015-02-28
  • 网络基础总结

    这周南老师出差了,由王老师给我们代课,这周我们主要学习了网络基础,相比着之前,主要是理论加理解。下面我总结一下。 处于21世纪的我们,互联网时代,网络在我们身边的各个角落,覆盖了我们的衣食住行,带来 很多方便;首先什么是网络, 家庭办公室,移动用户,总部,分支机构。。。都在用互联网相连着,省去了许多麻烦,时间,加快了办公效率; 资源共享的功能和优点:数据和应…

    2017-09-02
  • ansible

    运维工具介绍 Ansible Ansible优点:  Agentless       (去中心化)  Stupied Simple (上手简单,学习曲线平滑)  SSH by default (安全,无需安装客户端)  YAML no code,定制剧本 (语法简单,维护方便) 自动工具衍…

    Linux干货 2017-05-23

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-07 23:40

    对命令解释的很好,加强了对命令的记忆!