马哥教育网络班20期-第七周课程作业

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

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

    ]#mke2fs -t ext4 -b 2048 -L MYDATA -m 2 –O acl /dev/sda1

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

    ]# mkdir –p /data/mydata
    ]# mount -o noexec,nodiratime /dev/sdb1 /data/mydata

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

    ]# mkswap /dev/sda1;
    ]#swapon /dev/sda1;

3、写一个脚本

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

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

     #!/bin/bash
    fdisk -l |awk '/^Disk.*dev/{print $0}

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

    常用的raid级别有:raid0,raid1,raid5,raid10

    raid0:读写性能提升,无容错能力,最少两块硬盘

    raid1:读性能提升,写性能略有下降,有冗余能力,最少两块硬盘

    raid5:读写性能都有提升,有冗余能力,最少三块硬盘

    raid10:读写性能都有提升,有冗余能力,最少四块硬盘

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

    ]# mdadm -C /dev/md1 -n 2 -l 1 -c 128 -x 1 /dev/sdb1 /dev/sd2 /dev/sdb3

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

     ]# mdadm -C /dev/md2 -n 3 -l 5 -c 256 /dev/sdb5 /dev/sdb8 /dev/sdb9
    ]# mkfs -t ext4 /dev/md00
    ]# vim /etc/fstab
        /dev/md00  /backup ext4 nodiratime,acl,defaults 0 0

7、写一个脚本

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

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

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

#!/bin/bash
if [ $# -eq 0 ];then
        echo "please input a file path!"
        exit 1
fi
for file in $*;do
        echo "$file:$(cat awk.txt  |wc -l) lines"
done
        echo "------------"
        echo "total files:$#"

8、写一个脚本

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

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

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

#!/bin/biash
declare -i sum=0
if [ $# -lt 2 ];then
        echo "please at lease two char!"
        exit 3
fi
for user in $*;do
        if id $user >/dev/null ;then
                echo "$user is exist,create user fail!"
        else
                useradd $user && echo "$user" --stdin | passwd --stdin $user >/dev/null && echo "the user $user is create"
                let sum++
        fi
done
echo "create user:$sum"

   

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

#!/bin/bash
declare -i sum=0
for ((i=1;i<=20;i++));do
        useradd visitor$i
        echo "visitor$i is create!"
        sum+=$(id -u visitor$i)
done
echo "sum:$sum"

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

#!/bin/bash
declare -i sumline=0
declare -i sumspace=0
for file in {/etc/rc.d/rc.sysinit,/etc/rc.d/init.d/functions,/etc/fstab};do
        sumline+=$(grep -c "^#" $file)
        sumspace+=$(grep -c "^[[:space:]]*$" $file)
done
echo "start # line numbers:$sumline"
echo "start space line numbers:$sumspace"

    

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

#!/bin/bash
declare -i sum=0
awk -F: '$NF~/bash$/{printf "%-10s %-4u\n",$1,$3}' /etc/passwd
for i in $(awk -F: '$NF~/bash$/{print $3}' /etc/passwd);do
        sum+=$i
done
echo "^$"
echo "sum:$sum"

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

无附加组用户

]# groups root
root : root

有附加组用户

]# groups bin
bin : bin daemon sys

无附加组用户执行结果为1

]# groups root | awk -F: '{print $2}'|awk '{print NF}'
1

有附加组用户执行结果大于1

]# groups bin | awk -F: '{print $2}'|awk '{print NF}'
3
#!/bin/bash
declare -i sum=0
for i in $(awk -F: '{print $1}' /etc/passwd);do
        sum0=$(groups $i | awk -F: '{print $2}'|awk '{print NF}')
        if [ $sum0 -ge 2 ];then
                echo "$(groups $i | awk -F: '{print $1}')"
        let sum++
        fi
done
echo "users:$sum

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

]# pvcreate /dev/sdb{5,6,7,8}
]# vgcreate -s 8m myvg01 /dev/sdb{5,6,7,8}
]# lvcreate -L 5G -n mylv01 myvg01
]# mount -o acl /dev/myvg01/mylv01 /user

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

]# useradd -b /users magedu
]# su – magedu
]# cp /etc/m* ./

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

]# lvextend -L +4G /dev/myvg01/mylv01
]# resize2fs /dev/myvg01/mylv01

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

]# umount /dev/myvg01/mylv01
]# e2fsck /dev/myvg01/mylv01
]# resize2fs /dev/myvg01/mylv01
]# lvreduce -L -2G /dev/myvg01/mylv01

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

]#lvcreate -L 100m -p r -s -n snapmylv01 /dev/myvg01/mylv01

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

(0)
Net20_有马Net20_有马
上一篇 2016-09-07
下一篇 2016-09-07

相关推荐

  • 马哥团队带你领略阿里风景

    马哥团队带你揭秘互联网巨头公司—阿里巴巴 继马哥团队腾讯一行之后,4月中旬我们又来到了坐落于杭州的另一个互联网巨头公司。 波涛万里长江水,带你入杭州。 真情伴你走,春色为你留。 西湖烟水茫茫,百顷风潭,十里荷香。 风景甚好,怎能不去杭州的阿里巴巴转转呢? 带着“淡妆”,走,跟着我们前行…… 马哥更是笑道:“我们这次来是和马云谈合作的!让我们培训出来的更多同学…

    学员作品 2015-04-29
  • 马哥教育网络班20期+第10周博客作业

    4、写一个脚本   (1) 能接受四个参数:start, stop, restart, status    start: 输出“starting 脚本名 finished.”    …   (2) 其它任意参数,均报错退出;     #!bin/b…

    学员作品 2016-12-05
  • 文本处理工具sed及文本编辑器vim课程作业

    文本处理工具sed课程作业     1、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符         sed -n 's@^[[:space:]]\+@@p' /etc/grub2.cfg &…

    学员作品 2016-08-10
  • Linux文本处理工具sed

    sed工作原理:sed从文件中读取出来一行,并不会直接进行编辑处理而是会放在自己的模式空间内进行处理,处理的结果将会送到标准输出,默认情况下sed可以对每行文本进行处理,也可以让sed处理符合条件的行,我们可以利用正则表达式做文本过滤,模式空间有两种输出结果,一种是可以匹配到的,会根据编辑要求进行处理,例如删除,过滤字符串。另外一种则是匹配失败的,会直接进行…

    学员作品 2016-08-10
  • 文本处理工具系列(一):文本的查看、分析、统计和文本过滤工具

    1、文本的查看、分析和统计工具    <1>文本查看工具  cat tac rev more less head  tail  cut  paste       cat         -A:显示所…

    学员作品 2016-08-08
  • linux中用ACL实现灵活的权限管理

    ACL是什么?? ACL英文原意是Access Control List(访问控制列表).它能够实现灵活的权限管理,除了文件的所有者,所属组和其他人,设置相应的权限外,ACL允许你给任何用户或是用户组设置任何文件/目录的访问权限(注意的是有些不支持数字模式的权限给定) ACL有什么用?? 作为UGO权限管理的补充,acl有GUO办不到或者是难以办到的功能 &…

    Linux干货 2016-08-05

评论列表(2条)

  • 马哥教育
    马哥教育 2016-09-13 00:17

    有个明显的错误:创建一个大小为1G的swap分区,这题如果放在生产,就是一个故障。
    其它题目还是不错的,继续努力。

    • Queenie
      Queenie 2017-04-24 04:01

      @马哥教育I made the choice to explain to individual admiration within your outlook about it matter leave a good feedback at this point. Thank you very much so plenty when coniedsring composing caliber site content if you are as i did you just read.