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

相关推荐

  • Linux FHS-文件系统层级结构标准简要说明

    Linux FHS-文件系统层级结构标准简要说明 FHS(Filesystem Hierarchy Standard) FHS针对目录树架构对以下三个目录进行定义:     / (root, 根):与开机系统有关      /usr (unix software res…

    Linux干货 2017-03-26
  • DNS 子域授权和高级应用

    DNS 基础主从部分 http://www.178linux.com/12395 实验环境:     系统环境:Centos 6.7     关闭SELINUX:setenforce 0 #立即生效   (实际是宽容模式)     配置防火墙:iptables…

    Linux干货 2016-11-15
  • The second week’s homework

    一.linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 Linux 文件与目录管理 我们知道Linux的目录结构为树状结构,最顶级的目录为根目录 /。 其他目录通过挂载可以将它们添加到树中,通过解除挂载可以移除它们。 首先需要知道什么是绝对路径与相对路径。 绝对路径: 路径的写法,由根目录 / 写起,例如: /usr/shar…

    Linux干货 2016-12-12
  • 马哥教育网络班第25期-第1周作业

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

    Linux干货 2016-12-05
  • 用户和组管理

    Linux用户和用户组管理   Linux是个多用户多任务的分时操作系统,所有要使用系统资源的用户必须向系统管理员申请一个账号,然后以这个身份进入系统。用户登陆系统是也是一种验证方式,系统通过用户的UID(Username IDentification)这种机制来识别用户的身份和权限。每个用户账号都是唯一的用户名和用户口令。用户在登陆时键入正确的用…

    Linux干货 2016-08-07
  • CentOS程序包管理

    对于Linux系统而言,其能执行的程序为二进制格式,而对于程序开发者而言,直接利用二进制开发程序是不太现实的,所以一般都是利用高级语言来进行软件开发,其程序也即称为源代码;那么我们在对一个程序进行安装、升级、卸载、 查询、校验等操作时,需要对每个源代码进行编译成为二进制程序,那么显然是不太现实的。所以在各Linux发行版中一般都带有程序包管理器。 所谓程序包…

    Linux干货 2016-08-25

评论列表(1条)

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

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