Linux基础学习总结(六)

一、完成如下练习
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
vim:
  1. cp /etc/rc.sysinit /tmp/rc.sysinit
  2. vim/tmp/rc.sysinit
  3. :%s@^[[:space:]]\+@#&@g
sed:
  1. sed "s/\(^ \)/#\1/g" /tmp/rc.sysinit > tmp
  2. cat tmp > /tmp/rc.sysinit
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
  1. cp /boot/grub/grub.conf /tmp/
  2. vim /tmp/grub.conf
  3. :%s@^[[:space:]]\+@@g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
  1. vim/tmp/rc.sysinit
  2. :%s@^#[[:space:]]\+@@g
4、为/tmp/grub.conf文件中前三行的行首加#号;
vim编辑器
  1. :1,3s/^/#&/
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
vim编辑器
  1. :%s@\(enabled\|gpgcheck\)=0@\1=1@g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
  1. 0 */4 * * * cp -r /etc/ /tmp/backup/etc-$(date +%Y%m%d%H%M)
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
  1. 0 0 * * 2,4,6 cp -r /var/log/messages /backup/messages_logs/messages-$(date +%Y%m%d)
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
  1. 0 */2 * * * cat /proc/meminfo |grep "^S" >> /starts/menory.txt
9、工作日的工作时间内,每两小时执行一次echo “howdy”
  1. 0 9-18/2 * * 1,2,3,4,5 echo "howdy"
二、脚本编程练习
10、创建目录/tmp/testdir-当前日期时间; 
  1. mkdir -p /tmp/testdir-$(date +%F)
11、在此目录创建100个空文件:file1-file100
  1. #!/bin/bash
  2. cd /tmp
  3. for i in $(seq 1 100);do
  4. touch file-$i
  5. done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
命令实现:
  1. sed -n 'n;p' /etc/passwd |awk -F: '{print $1}'
脚本实现:
  1. #!/bin/bash
  2. declare -i i=0;
  3. cat /etc/passwd | while read -r line; do
  4. if [ $[ $i%2 ] == 0 ]; then
  5. echo $(echo $line | cut -d":" -f1);
  6. fi
  7. i=$i+1;
  8. done
13、创建10用户user10-user19;密码同用户名;
  1. #!/bin/bash
  2. for i in {10..19};do
  3. useradd user$i && echo "创建user$i用户成功"|passwd --stdin user$1 &> /dev/null
  4. done
14、在/tmp/创建10个空文件file10-file19; 
  1. #!/bin/bash
  2. for i in {10..19};do
  3. touch /tmp/file$i &> /dev/null
  4. done
15、把file10的属主和属组改为user10,依次类推。
  1. #!/bin/bash
  2. for i in {10..19};do
  3. chown user$i user$i /tmp/file$i &> /dev/null
  4. done

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

(0)
LeexideLeexide
上一篇 2016-10-30
下一篇 2016-10-30

相关推荐

  • linux系统启动之破坏与修复

    linux系统启动之破坏与修复:      通过这些实验,了解linux启动流程和相关文件,同时也预防系统发生问题能更快解决,而不用重装或者耽误时间:      实验:破坏MBR 446     dd if=/dev/zero of=/dev/sda bs=1 count=446…

    Linux干货 2017-03-30
  • http://www.jianshu.com/p/f1d0739b141f

    Linux干货 2017-07-30
  • 马哥教育网络班第25期-第1周作业

    一、计算机的组成及其功能 计算机由硬件与软件组成 硬件     1、运算器                           &…

    Linux干货 2016-12-05
  • Liunx 磁盘管理

    我们先来了解一下在Linux中磁盘的命名方式 命名:/dev/DEV_FILE    Sd :表示SCSI硬盘    Sda:表示SCSI硬盘中第一块硬盘,b表示第二块,以此类推 在Linux上次磁盘主要有两种分区方式MBR和GPT MBR分区格式最多有4个分区,可以是4个主分区,或者3个主分区和1个扩展分区,第一个逻…

    2017-08-21
  • 第六周学习总结

    写在前面 在互联网+的时代,网络显得越发重要,如果现在你一顿不吃饭可能还没事但是一个小时没网络,估计你都要疯了。那么网络到底是个啥呢?看不见又摸不着。拿着一台电脑怎么和网络建立连接呢?那么下面要讲解的内容或许可以给你解决个大概。 闲聊网络 如果让你修一栋房子你会一层一层的往上修,并且规划好一层用来开商铺,二层用来开超市,上面一层用来干嘛等等,其实网络也是一样…

    2018-01-08
  • 第八周作业(网络、bash脚本)

    1-3,计算机网络基础博客已总结,简要补充 协议的分层 为了使那些比较复杂的网络协议更加简单化。ISO根据各通信协议的功能将网络体系分成七层。 在这个分层中,下层为上一层提供服务。上下层之间进行交互时所遵循的约定叫做“接口”。同层之间的交互所遵循的约定叫做“协议” 说的更形象一点,两个中国人打电话这个通信。就可以分为两层,同层之间的叫协议,我说汉语,你也说汉…

    Linux干货 2016-12-18