马哥教育网络班22期+第6周课程练习 忍者乱太郎喻成

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

1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#
cp /etc/rc.d/rc.sysinit /tmp
方法一 vim法
在vim下用 : 进入命令行模式
  

  %s/^ /#\1/g

方法二 sed法

sed "s/\(^ \)/#\1/g" /tmp/rc.sysinit > tmp
cat tmp > /tmp/rc.sysinit
rm tmp

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
    cp /boot/grub/grub.conf /tmp/
vim法
命令行模式下使用

%s/^ .*//g

sed法

sed "s/^ .*//g" /tmp/grub.conf >tmp
cat tmp > /tmp/grub.conf
rm tmp

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

:%s/^\s\+//g

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

0,3s/^/#/g

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

%s/enabled=0/enabled=1/g

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

mkdir /backup
crontab -e #设置crontab任务
加入行 
* */4 * * * tar -cvf /backup/etc-$(date "+%Y%m%d%H%M") /etc

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

mkdir /backup

crontab -e #设置crontab任务
加入行

* * * * 2,4,6 cp /var/log/messages /backup/messages_logs/messages-$(date "+%Y%m%d")

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

mkdir stats
touch /stats/memory.txt

crontab -e #设置crontab任务
加入行

* */2 * * * cat /proc/meminfo/S* >> /stats/memory.txt

9、工作日的工作时间内,每两小时执行一次echo ""howdy""
crontab -e #设置crontab任务
加入行

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

脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;

mkdir /tmp/testdir-$(date +"%Y%m%d")

11、在此目录创建100个空文件:file1-file100
写一个脚本文件并执行
#!/bin/bash

cd /tmp
for i in $(seq 1 100);do
    touch file-$i
done


12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
写一个脚本文件并执行

#!/bin/bash

declare -i i=0;
cat /etc/passwd | while read -r line; do
        if [ $[ $i%2 ]  == 0 ]; then
                echo $(echo $line | cut -d":" -f1);
        fi
        i=$i+1;
done
        

13、创建10用户user10-user19;密码同用户名;
写一个脚本并执行
#!/bin/bash

for i in $(seq 10 19);do
        useradd user$i -p user$i;
done

14、在/tmp/创建10个空文件file10-file19;
写脚本
#!/bin/bash

for i in $(seq 10 19);do
    touch /tmp/file-$i
done

15、把file10的属主和属组改为user10,依次类推。
写脚本
#!/bin/bash

for i in $(seq 10 19);do
    chown user$i:user$i /tmp/file$i
done

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

(0)
chengyuchengyu
上一篇 2016-10-24
下一篇 2016-10-24

相关推荐

  • 谨记初心

    谨以此文记录我从小白成长的心路历程与技术的成长

    Linux干货 2018-03-26
  • Linux网络管理

                          Linux网络管理   本章内容: 网络概念 OSI七层模型 网络设备 TCP/IP IP地址 配置网络 实现网络组 测试网络 网络工具   网络用户应用程序: WEB浏览器(…

    系统运维 2016-09-12
  • linux根下的文件

    /boot:系统启动时要加载引导的静态文件,内核和ramdisk及grub等 /bin:系统自身启动和运行时可能用到的核心二进制程序,不能关联至独立分区。 /sbin:管理类基本命令,不能关联至独立分区,系统启动便会用到的程序。 /lib:基本共享库文件,以及内核模块文件 /lib64:专用于x86_64系统上的辅助共享库文件存放位置 /etc:大多数应用程…

    Linux干货 2017-03-30
  • N25-第4周作业(用户权限,grep用法)

    复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有访问权限.      [root@bogon ~]# chmod -R o=—,g=— /home/tuser1/ [root@bogon ~]# chmod -R o=,g= /home/tuser1/ 编辑/etc/…

    Linux干货 2016-12-26
  • Linux系统shell脚本

                                          &n…

    系统运维 2016-09-01
  • python env seup

    ffffffffffffffffffffffffffffffffffffff

    2018-03-12

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-25 13:13

    相关知识扩展的很好,但排版有点欠火候,你可以咨询一下455568219