人志建,则无敌—vim练习题

马哥网络班21期-第六周博客

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

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

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

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

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

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

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

[root@caicai ~]# vim /tmp/grub.conf
                   :1,3 s/^/#/

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

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

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

[root@caicai ~]# crontab -e        
0 */4 * * * cp -a /etc /backup/etc-date +%Y%m%d%H%M
[root@caicai ~]# crontab -l
0 */4 * * * cp -a /etc /backup/etc-date +%Y%m%d%H%M

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

[root@caicai ~]# crontab -e
0 0 * * 2,4,6 cp -a /var/log/messages /backup/messages_logs/messages-`date +%Y%m`
[root@caicai ~]# crontab -l
0 0 * * 2,4,6 cp -a /var/log/messages /backup/messages_logs/messages-`date +%Y%m`

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

[root@caicai ~]# crontab -e
0 */2 * * * grep --color -i "^s" /proc/meminfo > /stats/memory.txt
[root@caicai ~]# crontab -l
0 */2 * * * grep --color -i "^s" /proc/meminfo > /stats/memory.txt

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

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

脚本编程练习

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

#!/bin/bash

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

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

#!/bin/bash

for i in {1..100}; do
        touch file$idone

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

#!/bin/bash

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

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

#!/bin/bash

for i in {10..19}; do
        if id user$i &> /dev/null; then
                echo "have this only user."
        else
                useradd user$i &> /dev/null        
                echo "user$i" | passwd --stdin &> /dev/null        
                echo "user$i add over."
        fi
done

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

#!/bin/bash

for i in {10..19}; do
        touch file$i

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

#!/bin/bash

for i in {1..10}; do
        if id user$i && [ -e file$i ] &> /dev/null; then
                chown user$i:user$i file$i
                echo "file$i add user:user$i group:user$i"
        else
                echo "no file/user/group."
        fithen

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

(0)
N21_志建N21_志建
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • cnetos 6.7 内核编译

    简介     Linux内核的体积结构是单内核的,但充分借鉴了微内核设计体系的优点,为内核引入模块化机制,使得虽然是单内核、但工作在模块化的方式下、并且这个模块可以动态装载或卸载;Linux负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。如是我们在了解Linux内核的基础上根据自己的需…

    Linux干货 2016-02-27
  • grep,egrep及相应的正则表达式用法详解

    目录 1、grep简介     1.1、grep是什么     1.2、grep使用格式     1.3、grep常用选项 2、正则表达式与grep     2.1、正则表达式简介  &nb…

    系统运维 2016-08-22
  • until 练习题

    一、用until实现下列作业 1、每隔3秒钟到系统上获取已经登录的用户的信息;如果发现用户hacker登录,则将登录时间和主机记录于日志/var/log/login.log中,并提示该用户退出系统。   2、随机生成10以内的数字,实现猜字游戏,提示比较大或小,相等则退出 3、编写脚本,求100以内所有正整数之和   4、编写脚本,通过p…

    Linux干货 2016-08-17
  • 第二周部分练习

    (1)用户管理: 1.创建用户gentoo,附加组为bin和root,默认shell为/bin/csh,注释信息为”Gentoo Distribution” 使用id命令查看用户信息 使用cat命令查看配置文件/etc/passwd 2.创建下面的用户、组和组成员关系 名字为admins的组 用户natasha,使用admins作为附…

    2017-07-23
  • 使用Nmap扫描系统风险点

    0x00 迅速了解Nmap Nmap是一款扫描目标网络信息的工具,可以是黑客用来探测主机信息,收集情报的神器。也可以是运维人员扫描网络环境,及时发现系统漏洞的好帮手。 0x01 它的功能 1、主机发现(Host Discovery)#探测目标网络环境中有哪些主机是可以进行通信的,当然你也可以用ping命令试一下 2、端口扫描(Port S…

    Linux干货 2015-04-19
  • ​redis cluster 安装指南

    公司的很多项目在使用redis主从。由于coder的各种毁灭性操作,迫切需要一个能带故障恢复的架构。因此新版的cluster,开始了测试。 一、Cluster 理论基础 Cluster介绍 Redis集群是一个提供在多个Redis间节点间共享数据的程序集。 Redis集群并不支持处理多个keys的命令,因为这需要在不同的节点间移动数据,从而达不到像Redis…

    Linux干货 2016-02-14

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 15:13

    写的很好,排版也很棒,加油