N25 – Week6 作业

春节过去了,我们又开学了,又可以写博客,做作业了,好开心.N25 - Week6 作业

下面是第6周的博客作业:

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

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

[root@dhcp-10-129-6-166 ~]# head -30 /tmp/rc.sysinit | sed 's@^[[:space:]]@#&@g'
#!/bin/bash
#
# /etc/rc.d/rc.sysinit - run once at boot time
#
#
#
# # Rerun ourselves through initlog                                                // 通过 /sbin/initlog 命令重新运行自己
# if [ -z "$IN_INITLOG" -a -x /sbin/initlog ]; then                            // 条件是 :如果 IN_INITLOG 变量的值不为空,且 /sbin/initlog 可执行
#     exec /sbin/initlog -r /etc/rc.d/rc.sysinit                                // 调用 exec /sbin/initlog ,-r 是表示运行某个程序,为了将rc.sysinit的运行信息记到syslog里(/var/log/messages)
#        fi
#
#         ######################################################################################################################################################
#
#          HOSTNAME=`/bin/hostname`                            # 取得主机名
#          HOSTTYPE=`uname -m`                                    # 取得主机类型
#          unamer=`uname -r`                                          # 取得内核的 release 版本(例如 2.4.9.30-8)
#          eval version=`echo $unamer | awk -F '.' '{ print "(" $1 " " $2 ")" }'`            # 取得版本号
#
#               if [ -f /etc/sysconfig/network ]; then                # 如果存在 /etc/sysconfig/network ,则执行该文件。
#                   . /etc/sysconfig/network                             # network 文件主要控制是否启用网络、默认网关、主机名
#                       fi
#                       if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then            # 如果执行 network 文件后 HOSTNAME 为空或者为 "(none)" ,
#                           HOSTNAME=localhost                                                        # 则将主机名设置为 "localhost"
#                               fi
#
#
#                                 # Mount /proc and /sys (done here so volume labels can work with fsck)        # 接下来是挂载 /proc 和 /sys ,这样 fsck 才能使用卷标
#                                 mount -n -t proc /proc /proc                                                                      #  -n 表示不写 /etc/mtab ,这在 /etc 所在的文件系统为只读时用。因为此时的/还是只读的

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

[root@dhcp-10-129-6-166 ~]# sed 's@^[[:space:]]*@@g' /tmp/grub.cfg
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub2-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#
### BEGIN /etc/grub.d/00_header ###
set pager=1
if [ -s $prefix/grubenv ]; then
load_env
fi
...

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

root@dhcp-10-129-6-166 ~]# head -30 /tmp/rc.sysinit | sed 's@^#[[:space:]]*@@g'
!/bin/bash

/etc/rc.d/rc.sysinit - run once at boot time



 # Rerun ourselves through initlog                                                // 通过 /sbin/initlog 命令重新运行自己
 if [ -z "$IN_INITLOG" -a -x /sbin/initlog ]; then                            // 条件是 :如果 IN_INITLOG 变量的值不为空,且 /sbin/initlog 可执行
     exec /sbin/initlog -r /etc/rc.d/rc.sysinit                                // 调用 exec /sbin/initlog ,-r 是表示运行某个程序,为了将rc.sysinit的运行信息记到syslog里(/var/log/messages)
         fi

          ######################################################################################################################################################

           HOSTNAME=`/bin/hostname`                            # 取得主机名
           HOSTTYPE=`uname -m`                                    # 取得主机类型
           unamer=`uname -r`                                          # 取得内核的 release 版本(例如 2.4.9.30-8)

           eval version=`echo $unamer | awk -F '.' '{ print "(" $1 " " $2 ")" }'`            # 取得版本号

                if [ -f /etc/sysconfig/network ]; then                # 如果存在 /etc/sysconfig/network ,则执行该文件。
                    . /etc/sysconfig/network                             # network 文件主要控制是否启用网络、默认网关、主机名
                        fi

                        if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then            # 如果执行 network 文件后 HOSTNAME 为空或者为 "(none)" ,
                            HOSTNAME=localhost                                                        # 则将主机名设置为 "localhost"
                                fi


                                  # Mount /proc and /sys (done here so volume labels can work with fsck)        # 接下来是挂载 /proc 和 /sys ,这样 fsck 才能使用卷标
                                  mount -n -t proc /proc /proc                                                                      #  -n 表示不写 /etc/mtab ,这在 /etc 所在的文件系统为只读时用。因为此时的/还是只读的

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

[root@dhcp-10-129-6-166 ~]# sed '1,3s@^.*@#&@' grub.cfg.head3
##
## DO NOT EDIT THIS FILE
##

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

[root@dhcp-10-129-6-166 ~]# sed -r 's@(enabled|gpgcheck)=0@\1=1@g' /etc/yum.repos.d/CentOS-Media.repo
# CentOS-Media.repo
#
#  This repo can be used with mounted DVD media, verify the mount point for
#  CentOS-7.  You can use this repo and yum to install items directly off the
#  DVD ISO that we release.
#
# To use this repo, put in your DVD and use it with the other repos too:
#  yum --enablerepo=c7-media [command]
#
# or for ONLY the media repo, do this:
#
#  yum --disablerepo=\* --enablerepo=c7-media [command]
[c7-media]
name=CentOS-$releasever - Media
baseurl=file:///media/CentOS/
        file:///media/cdrom/
        file:///media/cdrecorder/
gpgcheck=1
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

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

[root@dhcp-10-129-6-166 ~]# cat /var/spool/cron/root
0 */4 * * * root find /etc | cpio -oc > /backup/etc-$(date +%Y%M%d)

7. 每周2,4,6备份/var/log/messages文件至/back/massages_logs/目录中,保存的文件名刑如message-20150402

0 0 * * */2 root find /var/log/messages | cpio -oc > /back/message_logs/message-$(date +%Y%M%d)

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

0 */2 * * * root grep "^S" /proc/meminfo >> /stats/memory.txt

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

0 9-18/2 * * 1-5 root echo "howdy"

脚本编程练习:

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

11. 在此目录创建100个空文件;file1-file100

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

[root@dhcp-10-129-6-166 ~]# cat ./my_shell/week6
!#/bin/bash
#create a directory under /tmp and named following by testdir-CURRENTDATE.
declare TEST_DIR=testdir-$(date +%Y%M%d)
mkdir /tmp/$TEST_DIR
#create 100 new empty file under the directory just created.
#use while struction to realize this
declare I=1
while [ $I -le 100 ]; do
        touch /tmp/$TEST_DIR/FILE$I
        let I++
done
#print out user name of even number line in file /etc/password
sed -n 'n;p' /etc/passwd | cut -d: -f 1
[root@dhcp-10-129-6-166 ~]#

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

(0)
JLJL
上一篇 2017-02-13 11:37
下一篇 2017-02-13 15:44

相关推荐

  • 第三周博客作业

      开始学习已经三周了,感觉到年底有些时间不够,作业也交的越来越晚,需要加紧学习的进度了。   1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。  最简单的实现题目要求的方法是使用cut命令只显示用户名并用sort命令排序去重: [root@localhost ~]# who |&nbs…

    Linux干货 2016-12-20
  • 马哥教育网络班22期+第十一周课程练习

    1、详细描述一次加密通讯的过程,结合图示最佳。第一阶段:ClientHello:    客户端(通常是浏览器)先向服务器发出加密通信的请求,这被叫做ClientHello请求。客户端向服务器提供以下信息:        支持的协议版本,比如TLS 1.2 &n…

    Linux干货 2016-12-27
  • 压缩及解压缩工具

    压缩和解压缩工具      压缩比      目的:时间换空间      CPU的时间 –> 磁盘空间 常见的压缩及解压缩工具: compress/uncompress, .Z gzip/gunzip, .gz bzip2…

    Linux干货 2016-08-22
  • 软链接与硬链接的区别

      这两牵扯到链接,那么先介绍以下链接。   在文件系统中,有一种可以把不同的文件相连接到一起的机制,这个机制叫做链接。通俗的话来说就是打开两个不同的文件夹,其实进去的是同一个。它可以把一个文件用不同的名字和路径来表示出来。系统通过inode(索引节点,文件唯一标识)来识别是否为同一个文件,无论系统上有有多少个链接,在磁盘上只有一个唯一的…

    2017-05-25
  • 第四周 文件操作

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@localhost ~]# cp -a /etc/skel /home/tuser1 [root@localhost ~]# chmod -R go= /home/tuser1 [root@localhost ~]…

    Linux干货 2017-12-24
  • mariadb之再次演练

    架构图如下: 1.按照架构图所示,准备机器,做好时间同步,主机名解析 192.168.42.150 node1 [proxySQL keepalived]192.168.42.151 node2 [proxySQL keepalived]192.168.42.152 node3 [mysql-master wha]192.168.42.153 node4 […

    Linux干货 2016-03-06

评论列表(1条)

  • 马哥教育
    马哥教育 2017-04-10 15:40

    sed默认是不修改源文件的,修改源文件需要加”-i”选项,加油!!!