26期全程班-第七周博客作业

1、创建一个10G分区,并格式为ext4文件系统;

   (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;

   (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;

# fdisk /dev/sda

# mkfs.ext4 -b 2048 -m 2 -L MYDATA /dev/sda5

# mount -o noexec,acl,noatime /dev/sda5 /data/mydata

2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之;

# fdisk /dev/sda

# mkswap /dev/sda6

# swapon /dev/sda6

3、写一个脚本

   (1)、获取并列出当前系统上的所有磁盘设备;

   (2)、显示每个磁盘设备上每个分区相关的空间使用信息;

#!/bin/bash
echo ” (1)、获取并列出当前系统上的所有磁盘设备;”
devs=`ls /dev/[sh]d[a-z]`
echo $devs
echo ” (2)、显示每个磁盘设备上每个分区相关的空间使用信息;”
for i in `fdisk -l $devs | grep -o “^/dev/[sh]d[a-z][[:digit:]]\>”`;do
        df -h $i
done

4、总结RAID的各个级别及其组合方式和性能的不同;

RAID0:将多块硬盘组合成一块硬盘使用,读写性能都有提升,磁盘利用率100%,无冗余能力,至少需要2块硬盘;

RAID1:将数据存储两份,读能力有提升,写能力下降,磁盘利用率50%,有冗余能力,至少需要两块硬盘

RAID5:将数据拆分存储并加入校验码技术,读写能力均有提升,磁盘利用率为 (磁盘数-1)/磁盘数,最多允许坏一块硬盘,至少需要3块硬盘;

RAID10:将磁盘先做raid1后再做raid0,读写能力均有提升,磁盘利用率为50%,每组最多允许坏一块硬盘,至少需要4块硬盘。

5、创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128k;

# fdisk /dev/sda

# mdadm -C /dev/md128 -n 2 -x 1 -c 128 -l 1 /dev/sda{5,6,7}

6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能;

# fdisk /dev/sda

# mdadm -C /dev/md129 -n 3 -l 5 -c 256 /dev/sda{8,9,10}

# mkfs.ext4 /dev/md129

# mkdir -p /backup

# echo << EOF >> /etc/fstab 
> /dev/md129      /backup     ext4       acl,noatime,defaults    0 0
> EOF

7、写一个脚本

   (1) 接受一个以上文件路径作为参数;

   (2) 显示每个文件拥有的行数;

   (3) 总结说明本次共为几个文件统计了其行数;

#!/bin/bash
if [ $# -le 0 ] ;then
        echo “请输入至少一个文件路径作为参数!”
        echo
else
        for i in $*;do
                echo “文件 `basename $i` 拥有 `wc -l $i| cut -d’ ‘ -f1`  行”
        done
echo
echo “总共为 $# 个文件统计了其行数。”
fi

8、写一个脚本

   (1) 传递两个以上字符串当作用户名;

   (2) 创建这些用户;且密码同用户名;

   (3) 总结说明共创建了几个用户;

#!/bin/bash
if [ $# -le 2 ] ;then
        echo “请在$0后面传递两个以上字符串当作用户名”
        echo
else
        for i in $*;do
                useradd $i &> /dev/null
                echo $i | passwd –stdin $i &> /dev/null
        done
echo
echo “总结说明共创建了$#个用户”
fi

9、写一个脚本,新建20个用户,visitor1-visitor20;计算他们的ID之和;

#!/bin/bash
uidsum=0
for i in {1..20};do
        username=visitor$i
        useradd $username &> /dev/null
        uid=`id -u ${username}`
        uidsum=$[$uidsum+$uid]
done
echo $uidsum

10、写一脚本,分别统计/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#号开头的行数之和,以及总的空白行数;

#!/bin/bash
chf1=”/etc/rc.d/rc.sysinit”
chf2=”/etc/rc.d/init.d/functions”
chf3=”/etc/fstab”
h1=`grep “^#” $chf1 | wc -l | cut -d’ ‘ -f1`
k1=`grep “^$” $chf1 | wc -l | cut -d’ ‘ -f1`
h2=`grep “^#” $chf2 | wc -l | cut -d’ ‘ -f1`
k2=`grep “^$” $chf2 | wc -l | cut -d’ ‘ -f1`
h3=`grep “^#” $chf3 | wc -l | cut -d’ ‘ -f1`
k3=`grep “^$” $chf3 | wc -l | cut -d’ ‘ -f1`
sumh=$((${h1}+${h2}+${h3}))
sumk=$((${k1}+${k2}+${k3}))
echo “#号开头的行数之和是$sumh;总的空白行数是$sumk”

11、写一个脚本,显示当前系统上所有默认shell为bash的用户的用户名、UID以及此类所有用户的UID之和;

#!/bin/bash
#grep “bash$” /etc/passwd | awk -F: ‘{print $1,$3}’
uidsum=0
for i in $(grep “bash$” /etc/passwd | cut -d’:’ -f1);do
        uid=`id -u $i`
        uidsum=$(($uidsum+$uid))
done
echo “默认shell为bash的用户的UID之和是$uidsum”

12、写一个脚本,显示当前系统上所有,拥有附加组的用户的用户名;并说明共有多少个此类用户;

#!/bin/bash
echo “以下用户拥有附加组”
grep “[^:]$” /etc/group|cut -d: -f 4
echo
echo “`grep “[^:]$” /etc/group|cut -d: -f 4 | wc -l | cut -d’ ‘ -f1`个拥有附加组的用户”

13、创建一个由至少两个物理卷组成的大小为20G的卷组;要求,PE大小为8M;而在卷组中创建一个大小为5G的逻辑卷mylv1,格式化为ext4文件系统,开机自动挂载至/users目录,支持acl;

14、新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录;

15、扩展mylv1至9G,确保扩展完成后原有数据完全可用;

16、缩减mylv1至7G,确保缩减完成后原有数据完全可用;

17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息;

 

原创文章,作者:N26-深圳-城市蜗牛,如若转载,请注明出处:http://www.178linux.com/68217

(0)
N26-深圳-城市蜗牛N26-深圳-城市蜗牛
上一篇 2017-03-16
下一篇 2017-03-17

相关推荐

  • 第六周作业

    vim编辑器的使用 vim在工作过程中有三种模式:编辑模式、输入模式、末行模式 编辑模式:也叫命令模式,键盘操作常被理解为编辑命令。 输入模式:在文本文件中输入内容。 末行模式:vim内置的命令行接口,执行vim的内置命令。 vim的使用 打开文件:#vim [OPTIONS]…[FILE]… +#:打开文件后,直接让光标处于第#行 …

    Linux干货 2017-07-04
  • vim的使用说明

    vim的使用说明 vim是一款功能丰富而强大的文本编辑器,vim是从 vi 发展出来的一个文本编辑器。其代码补全、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛的使用。 vim的使用非常方便,使用方法为:vim [options] [file ..] 1、vim可以对指定文件进行编辑,也可以直接启动vim编辑器进行编辑,对于打开指定文件编辑时可以加…

    Linux干货 2016-08-12
  • N22-第2周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示 cd、pwd、ls、alias、cat、more、less、tail、cut、wc、touch、mv、cp、rm pwd:用户当前所在目录 [xuc@localhost ~]$ pwd /home/xuc cd:切换目录  cd  [/PATH…

    Linux干货 2016-08-22
  • N22- 第五周

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost Packages]# grep -E "^(root|fedora|user1\>)" /etc/passwd | cut -d: -f…

    Linux干货 2016-11-21
  • 网络班N22期第五周博客作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@bogon ~]# cat /etc/passwd | grep -E "^(root|fedora|user1)\>" | cut -d:&nb…

    Linux干货 2016-09-15
  • M20-1 8月3号 ACL访问控制列表

    一、acl简介:   access control list,用于实现灵活的权限管理,除了文件的所有者,所属组和其他人,可以对更多的用户设置权限,而acl生效的顺序是所有者,自定义用户组,自定义组,其他人。 二、ACL的设置技巧:   getfacl:取得某个文件/目录的ACL设置项目   setfacl:设置某个目录/文件的A…

    Linux干货 2016-08-08

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-30 14:30

    测试了部分代码,脚本功能基本都已实现,但与此同时,作为博客,一定要注意代码的可读性,再接再励。