马哥教育网络班21期+第6周课程练习

请详细总结vim编辑器的使用并完成以下练习题

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

[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp

[root@localhost tmp]# vim rc.sysinit

末行模式

:%s/^[[:space:]]/#&/

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

[root@localhost tmp]# cp /boot/grub/grub.conf /tmp
[root@localhost tmp]# vim grub.conf

末行模式

:%s/^[[:space:]]\+//g

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

[root@localhost tmp]# vim rc.sysinit

末行模式

:%s/^#[[:space:]]\+//g


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

[root@localhost tmp]# vim grub.conf

末行模式

:1,3s/^/#&/


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

[root@localhost tmp]# vim /etc/yum.repos.d/CentOS-Media.repo

末行模式

:%s/enabled=0/enabled=1/

%s/gpgcheck=0/gpgcheck=1/


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

 *  */4  *  *  *  cp -r /etc  /backup/etc-$(date  +%Y%m%d%H%m)


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

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


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

*  * /2 *  *  * egrep -o "^s" /proc/meminfo  >>  /stats/memory.txt


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

* 9-17 /2 *  *  */1-5  echo "howdy"


脚本编程练习

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

#!/bin/bash/
#

mkdir /tmp/testdir-$(date +%c)

[root@localhost tmp]# ll

drwxr-xr-x. 2 root root  4096 7月  31 09:52 testdir-2016年07月31日


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

#!/bin/bash/
#
for i in {1..100}; do
    touch  /tmp/testdir/file$i
done

[root@localhost ~]# bash -x /tmp/mkdir.sh
+ for i in '{1..100}'
+ touch /tmp/file1
+ for i in '{1..100}'
+ touch /tmp/file2

…….

+ for i in '{1..100}'
+ touch /tmp/file100


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

#!/bin/bash

#

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


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

#!/bin/bash

#

    for i in {10..19}; do
        if id user$i &> /dev/null; then
                      echo "user$i exists."
        else
                     useradd user$i
        if [ $? -eq 0 ]; then
                      echo "user$i" | passwd –stdin user$i &> /dev/null
                      echo "Add user$i finished."
                        fi
                    fi
       done      


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

#!/bin/bash/
#
for i in {10..19}; do
    touch  /tmp/file$i
done


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

#!/bin/bash/
#
for i in {10..19}; do
    chown user$i:user$i file$i
done


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

(0)
lelexlelex
上一篇 2016-08-02 10:52
下一篇 2016-08-02 10:52

相关推荐

  • centos系列初步搭建LAMP

    centos6搭建LAMP 系统环境 ip=192.168.0.105 selinux为:setenforce 0 iptables 为stop 客户机需要修改hosts文件 1.192.168.2.105 www1.stuX.com2.192.168.2.105 www2.stuX.com 安装LAMP组件 1.yum install …

    Linux干货 2016-12-11
  • 马哥教育网络班21期-第二周课程作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cp即copy的简写,我们可以用它来复制一些文件即将,源文件的数据流复制到目的文件中。和下面要讲的rm,mv,一样都是一些非常基础的命令。关于这个命令,我们有个小窍门,那就是根据 ls file这个命令是否执行成功来判断file文件是否存在。 关于cp,我们有一些要点要注意: cp…

    Linux干货 2016-07-07
  • Linux终端类型介绍

    相关命令:tty 适合阅读人群:所有   终端机 终端(Computer terminal),是一台电子计算机或者计算机系统,用来让用户输入数据,及显示其计算结果的机器。又名终端机,它与一部独立的电脑不同,其实就是一种输入输出设备,一台电脑多人使用,每增加一个用户只须增加一台显示器和一套键盘鼠标就可以成为一个独立的终端,多用户可同时使用互相独立,跟…

    Linux干货 2016-10-14
  • 脚本作业–函数练习

    1、编写服务脚本/root/bin/testsrv.sh,完成如下要求(1) 脚本可接受参数:start, stop, restart, status(2) 如果参数非此四者之一,提示使用格式后报错退出(3) 如是start:则创建/var/lock/subsys/SCRIPT_NAME, 并显示“启动成功”考虑:如果事先已经启动过一次,该如何处理?(4) …

    Linux干货 2016-08-24
  • Mariadb数据库复制系列(五):基于SSL的复制

       实验五:基于SSL的主从复制功能的实现 在mysql服务器之间复制数据,默认情况下都是基于明文的,在有些场景中,明文传输会造成严重的数据安全隐患,因此,需要对mysql服务器之间的复制时的传输进行加密,传输加密方式可以基于SSL的会话进行 1、实验环境 2、私有CA的搭建 3、在主节点node72上生成证书签署请求、发送到私有CA服务器 4、在从节点n…

    Linux干货 2016-11-24
  • 马哥教育网络班21期+第4周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 # cp -a /etc/skel /home/tuser1 # chmod -R g-rwx,o-rwx /home/tuser1/ 2、编辑…

    Linux干货 2016-07-16

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-07 23:07

    博客作业写得不错,crontab部分需要注意一下,6,7,8,9题时间需要精确在分钟,加油!