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 22:04
下一篇 2017-03-17 17:27

相关推荐

  • linux文本处理工具

    linux文本处理工具 1.Linux 文件系统上的特殊权限: SUID     SGID   Sticky       进程的安全上下文:(1)任何一个可执行程序文件能不能启动为进程,取决发起者对程序文件是否拥有执行去权限       &…

    Linux干货 2017-02-25
  • 用户和组相关的配置文件总结

    包括:/etc/passwd,/etc/shadow,/etc/group,/etc/gshadow,/etc/login.defs,/etc/dufaults/useradd,/etc/skel/.*,/etc/gdm/custom.conf,   /etc/passwd 用户信息库文件;用于保存用户账号信息; 各字段含义依次为: 用户名:用户密…

    Linux干货 2016-10-25
  • Linux的文本处理工具练习题

    练习一:     1、找出ifconfig命令结果中本机的所有IPv4地址 2、查出分区空间使用率的最大百分比值 3、查出用户UID最大值的用户名、UID及shell类型 4、查出/tmp的权限,以数字方式显示  练习二:       1、显示/proc/meminfo文件中以大…

    Linux干货 2016-08-08
  • 马哥教育网络班21期-第一次课程作业

    计算机组成部分及其作用 1.总线 电子管道,携带信息字节并在各个部件间传输。分为地址总线,数据总线,控制总线。 CPU最大可寻址范围:2^N*M,  N为地址总线数量,M为数据总线数量。 2.I/O设备 I/O设备及输入输出设备,最常见的输入设备就是我们非常熟悉的键盘,鼠标,我们通过我们通过这些设备向计算机传达指令,让计算机完成我们想要它完成的工作…

    Linux干货 2016-06-29
  • Linux中的文件和目录的权限管理

    Linux系统通过完善的权限管理来限制每一个用户对于系统中文档和目录的访问。在Linux系统中,文件和目录的权限是有些差异的。一、权限介绍:如上所示,通过ll命令列出目录下文件的时候同时也会列出文件的权限,从第二位开始,一直到第九位,即rw-r–r–就是文件的权限描述:其中3位为一组:第一组:rw-:代表文件的属主(user)对文件的…

    Linux干货 2017-04-01
  • 基于Docker的工作流

    这次我们创建一个Hello world的web服务器。 一  mkdir -p identidock/app   #首先创建一个新的multiidentidock来存放我们的项目,在这个目录下面,创建一个app目录来存放Python代码。 touch app/identidock.py&n…

    Linux干货 2016-03-03

评论列表(1条)

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

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