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

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

Vim的使用.png

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

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

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

[root@localhost ~]#cp /boot/grub/grub.conf /tmp/
[root@localhost ~]# sed 's/^[[:space:]]\+//' /tmp/grub.conf

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

[root@localhost ~]#sed 's@^#[[:space:]]\+@@' /tmp/rc.sysinit

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

[root@localhost ~]#sed 1,3's/^/#/' /tmp/grub.conf

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

[root@localhost ~]#sed 's/=0/=1/' /etc/yum.repos.d/CentOS-Media.repo

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
1 */2 * * * grep "^S" /proc/meminfo >> /stats/memory.txt

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

[root@localhost ~]#crontab -e
1 */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 {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

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

#!/bin/bash
#
for i in {10..19};do
	if id user$i &> /dev/null;then
		echo "user$i has exist."
	else
		useradd user$i
		[ $? -eq 0 ] && echo "user$i" | passwd --stdin user$i &> /dev/null
	fi
done
echo "Add user$i finish"

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

#!/bin/bash
#
declare -i i=10
while [ $i -le 19 ];do
	if [ -d file$i ];then
		echo "file$i has exist."
	else
		mkdir -pv file$i
	fi
	let i++
done

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

#!/bin/bash
#
declare -i i=10
while [ $i -le 19 ];done
	if [ -d file$i ];then
		chown user$i:user$i file$i &> /dev/null
		echo "change file$i user group finish"
	else
		echo "No exist file"
	fi
	let i++
done

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

(0)
Net21_LionNet21_Lion
上一篇 2016-07-29
下一篇 2016-07-29

相关推荐

  • Linux启动流程

    内核级别: 1、POST开机加电自检 BIOS加载CMOS信息并进行开机自检,检测硬件设备是否正常并进行硬件设备初始化 2、Boot Sequence(BIOS):定义设备启动顺序 BIOS定义设备启动顺序,并读取启动设备数据加载硬盘上的第一个扇区MBR。 3、Boot Loader(MBR):bootloader功能实现 Boot Loader提供一个菜单…

    Linux干货 2016-11-23
  • 网络配置管理:ifcfg、iproute2和ss等相关命令介绍(不完整,需要后期完善)

    网络配置管理:ifcfg、iproute2和ss等相关命令介绍 ifcfg家族: ifconfig [interface] ifconfig interface [aftype] options | address …   -a :查看所有 接口信息 add<地址>:设置网络设备IPv6的ip地址 del<地址>…

    Linux干货 2017-01-19
  • 初学Linux

       已经学习了Linux一周了,从原来的设计网页、动画影视制作、3D模型到现在的黑白界面虚拟世界,从原来吃睡由我到现在重回高三生活,说实话,一开始还是不太能适应的,尤其是眼睛,酸胀痛。不过,越努力越幸运,也觉得linux其实很有意思。。以下是我第一篇微博的内容,也是我学习linux一周所总结的知识。 首先,学习一门知识就要先了解他的历史…

    Linux干货 2017-07-15
  • Liunx学习第一周之对目录及文件的操作总结

            Liunx学习的第一周已经结束,回顾这一周的学习,已经对Linux的发展历史有了初步的了解,也在老师的指导下成功的在虚拟机上安装了两个Liunx系统:centos6和centos7,然后在这两个Liunx系统的CLI模式下输入一个个命令,让系统执行各种任务,下面是第一周学习的几种命令的总结。 &nbsp…

    2017-07-15
  • 构建私有CA

    构建私有CA 我们采用openssl这个软件来实现 所有首先我们来看下该软件的配置文件 实现环境 centos 7.2 [root@redhat7 ~]# rpm -qc openssl  //可以看到该命令没有任何输出,我们可以思考该软件包还存在其他的支包 [root@redhat7 ~…

    Linux干货 2016-09-28
  • 实验删除分区表

    首先我们先对分区表做个备份 dd if=/dev/sda of=/app/mbr bs=1 count=512 把备份考到另一台设备上,不拷贝的话这台设备开不了机无法使用备份的文件 清除分区表 接下来需要在客户端操作 使用光盘救援模式启动 启用网络 选网卡 自动获取ip后默认下一步 接下来就是把刚刚拷到另一台设备上的文件拷贝回来   注:这是在光盘的根目录下…

    2017-12-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-29 15:57

    写的很好,排版也很棒,加油,周一到周五可以写成1-5,11题是创建文件