N22-冥界之王-第7周作业

1、创建一个10G分区,并格式为ext4文件系统;
   (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;
       在虚拟机里新添加一块磁盘20G,/dev/sdb
      

[root@CentOS6 ~]# fdisk /dev/sdb
        Welcome to fdisk (util-linux 2.23.2).
 
        Changes will remain in memory only, until you decide to write them.
        Be careful before using the write command.
 
        Device does not contain a recognized partition table
        Building a new DOS disklabel with disk identifier 0xe879321a.
 
        Command (m for help): n
        Partition type:
        p   primary (0 primary, 0 extended, 4 free)
        e   extended
        Select (default p): 
        Using default response p
        Partition number (1-4, default 1): 
        First sector (2048-41943039, default 2048): 
        Using default value 2048
        Last sector, +sectors or +size{K,M,G} (2048-41943039, default 41943039): +10G
        Partition 1 of type Linux and of size 10 GiB is set
 
        Command (m for help): w
        The partition table has been altered!
 
        Calling ioctl() to re-read partition table.
        Syncing disks.

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

[root@CentOS6 ~]# cat /proc/partitions
       [root@CentOS6 ~]# mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sdb1
       [root@CentOS6 ~]# mkdir -pv /data/mydata
       [root@CentOS6 ~]# echo '/dev/sdb1  /data/mydata  ext4  defaults,noexec,nodiratime,acl  0 0' >> /etc/fstab

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

  [root@CentOS6 ~]# fdisk /dev/sdb
     Command (m for help): n
     Partition type:
     p   primary (1 primary, 0 extended, 3 free)
     e   extended
     Select (default p): 
     Using default response p
     Partition number (2-4, default 2): 
     First sector (20973568-41943039, default 20973568): +1G
     Value out of range.
     First sector (20973568-41943039, default 20973568): 
     Using default value 20973568
     Last sector, +sectors or +size{K,M,G} (20973568-41943039, default 41943039): +1G
     Partition 2 of type Linux and of size 1 GiB is set
 
     Command (m for help): t
     Partition number (1,2, default 2): 2
     Hex code (type L to list all codes): 82
     Changed type of partition 'Linux' to 'Linux swap / Solaris'
 
     Command (m for help): w
     The partition table has been altered!
 
     Calling ioctl() to re-read partition table.
 
     WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
      The kernel still uses the old table. The new table will be used at
      the next reboot or after you run partprobe(8) or kpartx(8)
     Syncing disks.
 
     [root@CentOS6 ~]# partx -a /dev/sdb2
     [root@CentOS6 ~]# mkswap /dev/sdb2
       Setting up swapspace version 1, size = 1048572 KiB
      no label, UUID=0340f896-5d37-4c99-bb32-bd3cef571c01
     [root@CentOS6~]# swapon -a /dev/sdb2
       [root@CentOS6 ~]# swapon -s

    
3、写一个脚本
   (1)、获取并列出当前系统上的所有磁盘设备;
   (2)、显示每个磁盘设备上每个分区相关的空间使用信息;
 

   #!/bin/bash
    echo -e "All disks \n`fdisk -l | grep -o "[sh]d[a-z]" | uniq `\n"
    echo "Disk informations:"
    for disk in `fdisk -l | grep "^/dev/[sh]d[a-z][1-9]" | cut -d' ' -f1`; do
        df -h $disk
    done

   

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

Raid0本质上来讲根本不应该算是一种Raid级别,因为Raid0根本就没有冗余效果。Raid0只是用来指代将数据条带化分部到多块磁盘上的这种技术。它能够提高对数据的读写速度,但是对任何一个磁盘故障的情况下不提供任何保护措施。Raid0一般被用来提升针对临时文件的读写性能。对于长度大于一个Block(一个Block一般为4KB大小)的文件来说,Raid0可以并行的从多块磁盘来读写这个文件所对应的数据,所以也就提高了访问速度。然而,因为它没有冗余效果,所以它不能够在磁盘故障的情况下对数据提供保护。

  Raid1

  Raid1本质上也就是对每个写入操作进行镜像处理,即,将相同的数据同时写入两块或者多块磁盘。数据被写入不同的磁盘两次。Raid1原理上很简单,它提供优秀的数据保护能力,而且在磁盘故障之后,数据回拷的过程也是很迅速的。

  Raid1的一个不足之处就是成本过高。它可以说是一种最消耗存储空间的Raid级别了,因为Raid1对存储空间的需求量基本上等于实际数据存储数量的两倍。所以,如果你有300GB的数据,那么你就需要600GB的磁盘空间,也就是将你的磁盘成本增加了一倍。

  Raid3

  Raid3引入了数据校验(Parity)的方法,一旦一块磁盘发生故障,那么系统可以使用校验数据将丢失的数据重新计算出来。在一个Raid3的Raid组中,单独的一块磁盘被用来存放校验数据,用户数据则被条带化的分部到其它的磁盘上。如果一块磁盘故障,Raid3则使用校验数据来将失败磁盘上的数据重建(Reconstruct)出来。

  Raid5

  对于SMB来讲,Raid5几乎可以说是最为普遍使用的一种了。它在数据保护和经济性方面取得很好的平衡。在一个Raid5的Raid组中,所有的用户数据以及校验局都被条带化平均分部到了所有的磁盘上。然而,数据校验却引入了额外的负担,所以Raid5相对于Raid10来讲,会有一定的性能惩罚。不但写入数据的时候会因为数据校验带来的惩罚而使得性能降低,而且在磁盘故障之后的数据重建过程中,也会因为这种校验惩罚而导致重建时间大增。当一块磁盘故障之后,重建尚未完成的这段时间内,此时整个Raid5组就是一个单点故障了,一旦再有一块磁盘损坏,那么数据丢不保了。

  Raid6

  Raid6相当于在Raid5的基础之上在增加一个额外的冗余保护。它使用两个校验磁盘而不是一个,也就是说它能够抵御两块磁盘损坏之后的数据丢失风险。随着SATA磁盘的使用率日益提高,Raid6也正在被越来越多的人所使用。SATA盘相对于SCSI盘来讲更加廉价,但是可靠性不及后者,所以对SATA盘使用Raid6是最合适不过了。

  Raid10

  Raid10属于一种“嵌套”模式的Raid级别。也就是说,它结合了两种另外的Raid级别来实现额外的好处。Raid10首先将数据在磁盘之间进行镜像处理,然后再将镜像之后的数据进行条带化分布。条带化带来的好处就是大大提高了性能,而镜像则可以提供冗余性。Raid10既具有Raid1的简单性和冗余性,又具有条带化的高性能。像Raid1一样,Raid10对存储空间的耗费也是很高的,但是许多系统管理员依然愿意花费高价来使用Raid10

  Raid10的另一个变种是Raid01,Raid01则是先将数据条带化分布到多个磁盘之上,然后再将多个条带化之后的数据集进行镜像处理。Raid01相对于Raid10来讲在健壮性方面有所降低,所以它并不及Raid10受欢迎。除此之外,还有另外的一些Raid级别,比如Raid2,但是Raid2从来没被真正的商业化使用过,但是对于一些极少的情况下,比如针对大尺寸的连续分布的文件的存储系统中,偶尔会被使用。还有Raid4等。

  如果你追求性能,那么Raid10是最好不过了。如果追求经济性,那么Raid5会在保证数据冗余性的前提下,耗费最少的磁盘数量。当你需要对数据进行额外层次的保护的时候,那么可以使用Raid6.在这些例子中,请尽量保证Raid组中拥有足够数量的热备磁盘(当其他磁盘故障之后用于立即顶替的额外磁盘)。个空闲盘,而且CHUNK大小为128k;

    
5、创建一个大小为10G的RAID1,要求有一Raid0

  

mdadm -C /dev/md0 -a yes -l 1 -c 128 -n 2  -x 1 /dev/sdc{6,7,8}

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

mdadm -C /dev/md0 -a yes -n 3 -c 256 -l 5 /dev/sdc{1,2,3}
 mke2fs -t ext4 /dev/md0

    
7、写一个脚本
   (1) 接受一个以上文件路径作为参数;
   (2) 显示每个文件拥有的行数;
   (3) 总结说明本次共为几个文件统计了其行数;
 

单独参数版本:

       for((i=1;i<=$number;i++));do
           echo -n "please input $i file name:"
           read  file[${i}]
       done
     for((i=1;i<=$number;i++));do
           if [ -f ${file[${i}]} ];then
             echo "file ${file[${i}]} is exists."
            else
              echo "file ${file[${i}]} is not exists."
              number=$[$number-1]
              continue
            fi  
 
            echo   "file ${file[${i}]} is lines"  | cat ${file[${i}]} | wc -l
     done
         echo "total $number files."

全参数版本:

     #!/bin/bash
     sum=$#
     if [ $# -lt 1 ];then
        echo "please input a than number 1 files."
        exit 2
      fi
     for file in $@;do
        if [ -f "$file" ];then
           echo "filename is $file,lines are `cat $file | wc -l`."
         else
           echo "$file is no"
           sum=$[$sum-1]
        fi
     done
     echo "files are $sum."

   
8、写一个脚本
   (1) 传递两个以上字符串当作用户名;
   (2) 创建这些用户;且密码同用户名;
   (3) 总结说明共创建了几个用户;
   
   
  

declare -x username
   echo -n "input your want add user count number[1-9]:"
   read number
   if echo "$number" | grep -qE '^[1-9]$'; then
         echo "'$number' is a number."
   else
         echo "'$number' not scope."
         exit 2
   fi
   echo  "$number args: please input username:"
   for((i=1;i<=$number;i++));do
      echo -n "please input $i username:"
      read  username[${i}]
   done
   for((i=1;i<=$number;i++));do
       useradd ${username[${i}]}
       echo ${username[${i}]} | passwd ${username[${i}]} --stdin
   done
   echo "total create $number users."

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

for((i=1;i<=20;i++));do
     useradd visitor$i;
     echo "visitor$i" | passwd visitor$i --stdin
   done
   declare -a number
   number=(`cat /etc/passwd | grep "visitor" | cut -d: -f3`)
   declare sum=0
   for((i=0;i<${#number[*]};i++));do
     sum=$[$sum+${number[i]}]
   done
   echo $sum

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

file=(/etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab)
sum=0
sumbegin=0
for((i=0;i<=${#file[*]}-1;i++)); do
  echo "${file[i]} 已#开头的行的行数是:" 
   cat ${file[i]} | grep -E "^#" | wc -l
  echo "${file[i]} 空白的行的行数是:"
  cat ${file[i]} | grep -E "^[[:space:]]+" | wc -l
  sum=$[$sum+`cat ${file[i]} | grep -E "^[[:space:]]+" | wc -l`]
  sumbegin=$[$sumbegin+`cat ${file[i]} | grep -E "^#" | wc -l`]
done
  echo "3个文件的空白行总和 $sum"
  echo "3个文件#开头的文件总行数和 $sumbegin"

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

cat /etc/passwd | grep '/bin/bash'| sort | awk -F: '{print $1}' | awk -v RS="" '{gsub("\n"," ");print}'
number=(`cat /etc/passwd | grep '/bin/bash' |  cut -d: -f3`)
sum=0
for((i=0;i<${#number[*]}-1;i++));do
  sum=$[$sum+${number[i]}]
done
echo "bash uid sum is $sum."

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

     cat /etc/group | cut -d: -f1,4 | awk -F: '{if ($2!="") printf "%s:%s\n",$1,$2}' | cut -d: -f1 | sort
     cat /etc/group | cut -d: -f1,4 | awk -F: '{if ($2!="") printf "%s:%s\n",$1,$2}' | wc -l

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

    fdisk -l /dev/sdc
    pvcreate /dev/sdc{1,2}
    vgcreate -s 8M myvg1 /dev/sdc1 /dev/sdc2
    lvcreate -L 5G -n mylv1 myvg1
    mke2fs -t ext4 /dev/myvg1/mylv1
    mkdir /users
    在/etc/fstab下添加/dev/myvg1/mylv1 /users ext4 defaults,acl 0 0

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

  useradd -d /users/magedu magedu
  su magedu
  cp -r /etc /home/megedu

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

lvextend -L +2g /dev/myvg1/mylv1 /dev/sdc{1,2}
resize2fs /dev/myvg1/mylv1

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

umount /dev/myvg1/mylv1
e2fsck -f /dev/myvg1/mylv1
lvreduce -L -2g /dev/myvg1/mylv1
resize2fs /dev/myvg1/mylv1

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

 lvcreate -L 3g -p r -s -n lihui_snapshot /dev/myvg1/mylv1

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

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-27 09:51

    写的很棒,看的出来很用心,希望继续保持

联系我们

400-080-6560

在线咨询

工作时间:周一至周五,9:30-18:30,节假日同时也值班

QR code