马哥教育21期网络班—第六周课程+练习—-成长进行时

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

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

[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/rc.sysinit 
[root@localhost tmp]# vim rc.sysinit:%s@^[[:space:]]\+@#&@g:%s/^[[:space:]]\+/#&/

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

[root@localhost tmp]# cp /boot/grub/grub.conf /tmp/grub.conf
[root@localhost tmp]# vim grub.conf :%s/^[[:space:]]\+//g

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

[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/rc.sysinit 
[root@localhost tmp]# vim rc.sysinit:%s@^#[[:space:]]\+@@g

4、为/tmp/grub.conf文件中前三行的行首加#号; [root@localhost ~]# cp /boot/grub/grub.conf

[root@localhost ~]# cp /boot/grub/grub.conf /tmp/grub.conf
[root@localhost tmp]# vim grub.conf:1,3s@.*@#&@g

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

[root@localhost ~]# vim /etc/yum.repos.d/CentOS-Media.repo 
:%s@=[0-1]@=1@g

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

[root@localhost ~]# crontab -e 
* */4 * * * cp -rf /etc /backup/etc-`date +\%Y\%m\%d\%H\%M`

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

[root@localhost ~]# crontab -e
 1 * * * 2,4,6 cp /var/log/messages /backup/messages_logs/messages-`date +\%Y\%m\%d`

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

[root@localhost ~]# crontab -e 
* */2 * * * grep "^s" /proc/meminfo >> /stats/memory.txt

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

[root@localhost ~]# crontab -e
 * */2 * * 1,2,3,4,5 echo "howdy"

脚本编程练习

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

#/bin/bash 
#mkdir -p /tmp/testdir-`date +\%Y\%m\%d\%H\%M`

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

#/bin/bash 
#for i in  {1..100};do
mkdir -p file$i
done

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

#!/bin/bash
sed -n 'n;p' /etc/passwd | cut -d: -f1 >> /tmp/user.txt
[root@localhost tmp]# cat /tmp/user.txtbin
adm
sync
halt
uucp
games
ftp
dbus
vcsa
rtkit
abrt
nfsnobody
gdm
apache
postfix
sshd

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

for i in {10..19}; do
if id user$i &> /dev/null; then
echo "user$i exists."elseuseradd 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;

for i in {10..19}; do
if [ -d /tmp/file$i ]; then
echo "file$i exists."else
mkdir -p  /tmp/file$
if[ $? -eq 0 ]; then
echo "Add file$i finished."
fi
fi
done

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

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

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

(0)
N21_ DominicN21_ Dominic
上一篇 2016-08-03 15:16
下一篇 2016-08-03 15:59

相关推荐

  • Python from entry to abandon 4

        python from entry to abandon系列的收官之作    本篇博客将会介绍《简明Python教程》的最后四章内容。并在最后附上对于本书的个人评价和下阶段自学Python系列博客更新的计划。    13.异常   &nbsp…

    Linux干货 2017-04-07
  • 网络接口配置bonding

    Bonding 就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。 Bonding的工作模式 Mode 0 (balance-rr)     轮转(…

    Linux干货 2016-09-09
  • Linux文件夹作用

    适用对象:本文适用于初学Linux以及有志于学习Linux的朋友们。   Linux文件系统形状类似于倒置的树状结构,所有的文件或文件夹都可以被认为是根目录/的子目录。 在Linux系统安装完成之后,系统会自动在/目录下创建一些文件,而这些文件都有自己特殊的作用。本文就/下的目录做个简单的介绍。 /bin:存放所有用户使用的二进制可执行命令 /bo…

    Linux干货 2016-10-19
  • Linux中的账号管理之命令的使用(中)

    linux中账号管理的命令非常多,我这里主要介绍最常见的几个命令,这些命令分别是针对用户和组的管理 主要介绍对用户管理的命令: 一、用户创建:useradd useradd命令用于Linux中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实…

    Linux干货 2016-08-07
  • RHCE系列之LVM—-操作篇

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1350942    上一篇为大家介绍LVM的一些概念,这一篇就教大家一些日常的LVM的操作吧。毕竟,理论还是要应用到实战中来的嘛。 &nb…

    Linux干货 2016-08-15
  • 关于软硬链接那些事儿

           小编这周接触到了链接,那么重点来了,啥是链接呢小编觉得链接简单来说就是一种共享的方式,比如我们去逛超市,超市的入口就是‘链接’。在Linux中,链接又分为软连接和硬链接,想要了解他俩,就得先了解几个基本概念。 一:Inode       我们知道文件包含数据和元数据,它的数据…

    Linux干货 2017-07-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-03 15:31

    命令,跟vim命令模式混合在一起了,希望能耐心点