第六周: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
下一篇 2016-10-26

相关推荐

  • ACL概述

    ACL概述 一、什么是ACL ACL是linux系统中一种被称为访问控制列表的权限控制方法,它是一种权限分配之外的普遍范式。在一般情况下,要确认三个权限组:owner、group和other。而使用ACL则可以增加权限给其他用户或组别,不再仅仅是在“other”中定义权限,可以允许指定的用户拥有不同于其所属组的权限。 ACL支持多种Linux文件系统,包括e…

    2017-07-29
  • shell脚本基础

    shell脚本基础 变量 bash的变量:  环境变量  本地变量  位置变量  特殊变量 本地变量:bash:作用域为整个bash进程 局部变量:作用域为当前代码段 local VARNAME=VALUE 引用变量:${VARNAME} 环境变量:作用域为当前的shell进程及其子进程 export VARNAME=…

    Linux干货 2017-04-16
  • bash的一些特性

    bash的字符串处理工具 字符串切片: ${var:offset:number} 取字符串的子串; 取字符串的最右侧的几个字符:${var: -length} 注意:冒号后必须有一个空白字符; 基于模式取子串; ${var#*word}: 其中word是指定的分隔符;功能:自左而右,查找var变量中所存储的字符串中,第一次出现word分隔符,删除字符串开头至…

    Linux干货 2016-08-24
  • 网络配置、nmcli

    CentOS 7 网络属性配置    rhel6 之前,网络接口使用连续号码命名:eth0 、eth1 等, 当增加或删除网卡时,名称可能会 发生变化    rhel7 使用基于硬件,设备拓扑和设置类型 命名:    (1) 网卡命名机制    &n…

    Linux干货 2016-09-23
  • shell脚本之选择与执行

    流程控制  过程式编程语言: 顺序执行 选择执行 循环执行 选择执行:if语句  注意:if语句可嵌套  单分支 if 判断条件:then 条件为真的分支代码 fi  双分支 if 判断条件; then 条件为真的分支代码 else 条件为假的分支代码 fi 多分支 if…

    Linux干货 2016-09-19