sed命令、crontab任务、简单脚本练习(21期网络班第六周博客作业)

vim使用: 直接使用sed模式空间演示,基本语法与vim命令模式类似(需注意vim默认定界为当前行,一般需要在前面加1,$定界为全文,而sed不需要)

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

     sed 's/^\([[:space:]]\+\)/#\1/' /etc/rc.d/rc.sysinit

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

     sed 's/^[[:space:]]*//' /boot/grub/grub.conf

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

     sed 's/^#[[:space:]]\+//' /etc/rc.d/rc.sysinit

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

     sed '1,3s/\(^.*$\)/#\1/' /boot/grub/grub.conf

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

     sed 's/enabled=0/enabled=1/g' /etc/yum.repos.d/CentOS-Media.repo | sed 's/gpgcheck=0/gpgcheck=1/g'

crontab计划任务部分:可以通过man 5 crontab查看使用实例

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

     0 */4 * * * cp -af /etc /backup/etc-`date +%Y%m%d%H`

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

        0 1 * * 2,4,6 cp -af /var/log/messages /backup/messages-`date +%Y%m%d`

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

     0 */2 * * * sed -n '/^S/p' /proc/meminfo &> /stats/memory.txt

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

     0 8-17/2 * * 1-5 echo "howdy"

脚本编程练习

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

       mkdir /tmp/testdir-`date +%Y%m%d%H%M%S`

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

       #!/bin/bash

       #

       for ((i=1;i<=100;i++));do

          touch /tmp/testdir-20160805171428/file$i

       done

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

       sed -n '2~2p' /etc/passwd

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

       #!/bin/bash

       #

       for((i=0;i<=9;i++));do

          useradd user1$i && echo "user1$i is ok!"

          echo "user1$i" | passwd –stdin user1$i &>> /dev/null

       done

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

       #!/bin/bash

       #

       for ((i=1;i<=9;i++));do

          touch /tmp/file1$i

       done

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

       #!/bin/bash

       #       

       for((i=10;i<=19;i++));do

          chown user$i:user$i /tmp/file$i

       done

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

(0)
xaochuan1987xaochuan1987
上一篇 2016-08-22
下一篇 2016-08-22

相关推荐

  • 人志建,则无敌—if、case练习

    马哥21期网络班-9周博客作业 1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash for i in `cut -d: -f7 /etc/passwd`;&…

    Linux干货 2016-09-05
  • CA服务器的搭建以及证书签署、dropbear的编译安装

    CA服务器的搭建以及证书签署、dropbear的编译安装 一、CA Server和Client: 1、CA server:创建私钥CA (1)   openssl的配置文件:/etc/pki/tls/openssl.conf   如果Client端的申请是来自不同的国家,则需要将下图中红色框内的三项,由“match”改为“opt…

    Linux干货 2016-09-23
  • Xen虚拟化平台安装及实时迁移

    前言 Xen是英国剑桥大学计算机实验室开发的一个虚拟化开源项目,Xen可以在一套物理硬件上安全的执行多个虚拟机,它和操作平台结合的极为密切,占用的资源极少。以高性能、占用资源少著称,赢得了IBM、AMD、HP、Redhat和Novell等众多世界级软硬件厂商的高度认可和大力支持,已被国内外众多企事业用户用来搭建高性能的虚拟化平台。 Xen虚拟化类型 Xen对…

    Linux干货 2015-07-19
  • 优云云监控:先定一个运维小目标,比方监控它10000台主机

    “想做世界最好是对的,但是最好先定一个能达到的小目标,比方说我先挣它一个亿。”,王首富云淡风轻地给各行各业提供了一个很好的Roadmap,包括我们运维。的确,如今数据中心的规模增长速度也已像一匹脱缰的野马,各地都频频建设起超大型数据中心。按工信部的定义,超大型是指规模大于等于一万个标准机架的数据中心,考虑到虚拟化技术的使用,实际上需要运维的主机规模很容易超过…

    系统运维 2016-12-05
  • 权限管理

     权限管理:  ls -l       rwxrwxrwx:              左三位:定义user(owner)的权限              中三位:定义g…

    Linux干货 2016-12-21
  • CentOS程序包管理

    对于Linux系统而言,其能执行的程序为二进制格式,而对于程序开发者而言,直接利用二进制开发程序是不太现实的,所以一般都是利用高级语言来进行软件开发,其程序也即称为源代码;那么我们在对一个程序进行安装、升级、卸载、 查询、校验等操作时,需要对每个源代码进行编译成为二进制程序,那么显然是不太现实的。所以在各Linux发行版中一般都带有程序包管理器。 所谓程序包…

    Linux干货 2016-08-25

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-07 17:37

    完成的非常的好,5题可以在vim中使用 :%s@\(gpgcheck\|enabled\)=0@\1=1@,排版可以在漂亮一点的。