马哥教育网络班21期-第七周课程练习

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

    #fdisk /dev/sdb (n;p;1;+10G;w)
    #partx -a -n 1 /dev/sdb

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

    #mke2fs -t ext4 -b 2048 -m 2 -L 'MYDATA' /dev/sdb1
    #tune2fs -o acl /dev/sdb1

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

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

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

    #fdisk /dev/sdb  (n;p;2;+1G;t;2;82;w)
    #partx -a /dev/sdb
    #mkswap /dev/sdb2
    #swapon /dev/sdb2

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

#!/bin/bash
#
fdisk -l |grep "^/"|cut -d" " -f1
df -h

4、总结RAID的各个级别及其组合方式和性能的不同;
    RAID0(条带卷)
        组合方式:将数据分成若干chunk,分散到每个硬盘中
        性能:读、写速度是RAID中最快的,无容错能力

        可用空间:N*min(S1,S2,…)

    RAID1(镜像卷)

        组合方式:将数据分成若干chunk,复制到每个硬盘中

        性能:读性能提升、写性能略下降,有冗余能力     

        可用空间:1*min(S1,S2,…)

    RAID4
        组合方式:3个硬盘中1个硬盘存储校验码
        性能:有容错能力

    RAID5
        组合方式:在RAID-4的基础上,轮流用硬盘存储校验码
        性能:读、写性能提升,有容错能力
        可用空间: (N-1)*min(S1,S2,S3,…)

    RAID6

        组合方式:轮流用两块硬盘做校验盘
        性能:读、写性能提升,有容错能力(2块磁盘)
        可用空间: (N-2)*min(S1,S2,S3,S4,…)

    RAID10

        组合方式:先两两一组进行RAID1,后用RAID0

        性能:读、写性能提升,每组镜像最多只能坏一块 

        可用空间: N*min(S1,S2,S3,S4…)/2

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

#fdisk /dev/sdb (n;e;3;+10;t;3;fd;w),依次创建sdb4,sdb5
#mdadm -C /dev/md1 -n2 -x1 -a yes -c128 -l1 /dev/sdb{3,4,5}

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

    #fdisk /dev/sdb (n;e;6;+4G;t;6;fd;w),依次创建sdb7,sdb8
    #mdadm -C /dev/md2 -n3 -a yes -c256 -l5 /dev/sdb{6,7,8}
    #mke2fs -t ext4 /dev/md1

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

#!/bin/bash

declare -i i=0

if [ $# -lt 1 ];then
  echo "please input at least one file path"    
  exit 1
fi
for file in $*;do
  if [ -f $file ];then
    echo "The $file line number : $(wc -l $file|cut -d"" -f1)"
    let i++   
  else
    echo "please input the correct file path"
  fi
done
      
echo "the statisticsed file is $i"

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

#!/bin/bash

declare -i i=0

if [ $# lt 2 ];then 
    echo "at least input two usernames"
    exit 1
fi

for username in $*;do
    id $username &> /dev/null
    if [ $? -eq 0 ];then
        echo "$username existed"
    else
        useradd $username
        echo "$username" |passwd --stdin $username &>/dev/null
        let i++
    fi
done

echo "the user added is $i"

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

#!/bin/bash

declare -i sum=0

for i in `seq 1 20`;do 
    useradd visitor$i
    sum+=$(id -u visitor$i)
done

echo "the sum of all user's ID’ is :$sum"

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

#!/bin/bash

declare -i sum1=0
declare -i sum2=0

for i in {/etc/rc.d/rc.sysinit,/etc/rc.d/init.d/functions,/etc/fstab};do
    sum1+=$(grep -c '^#' $i)
    sum2+=$(grep -c '^$' $i)
done

echo "the sum of start by # is $sum1"
echo "the sum of space line is $sum2"

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

#!/bin/bash

declare -i sum=0
declare -i i=0

grep "\/bin\/bash$" /etc/passwd|awk -v FS=":" '{print $1,"\t",$3}'

for i in $(awk -F: '/bash$/{print $3}' /etc/passwd);do 
    let sum+=$i
done

echo "the sum of uid is $sum"

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

#!/bin/bash 

declare -i i=0

for user in `cut -d: -f1 /etc/passwd`;do 
    group=$(id $user|cut -d" " -f3|awk -F, '{print $2}')
    if [ -n "$group" ];then
        echo $user
        let i++
    fi
done
echo "user number is $i"

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

    #fdisk /dev/sdb {n;e;9;+10G;t;9;8e;w},依次创建sdb10
    #pvcreat /dev/sdb9
    #pvcreat /dev/sdb10
    #vgcreat myvg -s 8M  /dev/sdb{9,10}
    #lvcreat -L 5G -n mylv1 myvg
    #mk2fs -t ext4 /dev/myvg/mvlv1

在/etc/fstab里新增一行

/dev/myvg/mglv1    /users        ext4        default,acl            0  0

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

    #useradd -d /users/magedu magedu
    #su - magedu
    #cp /etc/ .

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

    #umount /dev/myvg/mylv1
    #lvextend -L 9G /dev/myvg/mylv1
    #resize2fs /dev/myvg/mvlv1
    #mount /dev/myvg/mylv1 /users

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

    #umount /dev/myvg/mvlv1
    #e2fsck -f /dev/myvg/mvlv1
    #resize2fs /dev/myvg/mvlv1
    #lvreduce -L 7G /dev/myvg/mvlv1
    #mount /dev/myvg/mvlv1 /users/

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

    #lvcreat -L 5G -p r -s -n mylv1.snapshot /dev/myvg/mvlv1

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

(0)
ππ
上一篇 2016-08-22
下一篇 2016-08-22

相关推荐

  • LVM(逻辑卷管理)

    LVM 逻辑卷管理 概述:      LVM是将一个或多个硬盘的分区在逻辑上集合,相当于一个大硬盘来使用,当硬盘的空间不够使用的时候,可以继续将其它的硬盘的分区加入其中,这样可以实现磁盘空间的动态管理,相对于普通的磁盘分区有很大的灵活性。与传统的磁盘与分区相比,LVM为计算机提供了更高层次的磁盘存储。它使系统管理员可以更方便的为…

    Linux干货 2016-09-05
  • 正则表达式基础以及grep的简单使用

    正则表达式基础以及grep的简单使用   1,定义 正则表达式是你所定义的模式模板,Linux可以用它来过滤文本。Linux工具(比如grep、sed、gawk)能够在处理数据时使用正则表达式对数据进行模式匹配。如果数据匹配模式,它就会被接受并进一步处理;如果数据不匹配,它就会被滤掉。 2,正则表达式的原则 (1)正则表达式模式都区分大小写。(2)…

    2017-04-09
  • Linux基础知识之命令的语法通用格式

    #COMMAND OPTIONS ARGUMENTS 1.COMMAND:   (1)发起一命令:请求内核将某个二进制程序运行为一个进程: 程序–>进程 静态–>动态 (有声明周期)   (2)命令本身是一个可执行的程序文件:二进制格式的文件,有时候会调用共享库文件 多数系统程序文件都存放在:/bin,…

    Linux干货 2016-07-07
  • Mogilefs使用Nginx实现代理访问

    MogileFS介绍:  MogileFS是一个开源的分布式文件存储系统,由LiveJournal旗下的DangaInteracitve公司研发。可支持文件自动备非的功能,提供高可用性和高可扩展性。 MogileFS组件:  trackers:   MoglieFS的调度器,是mogileFS的核心,访问入口。  功能…

    Linux干货 2015-08-06
  • 第一周初入Linux世界 —马哥教育网络班N22_第一周课程练习

    一、描述计算机的组成及其功能        计算机体系结构以图灵机理论为基础,属于冯·诺依曼体系结构。    计算机由运算器、控制器、寄存器、输入输出设备组成            运算器:是计算机中执行各种算术和逻辑运算操作的部件。运算器…

    Linux干货 2016-08-15
  • 18页PPT带你深度解读运维自动化

    一、概述    在前面的文章中,提到【运维的本质—可视化】,在其中着重强调是自动化的可视化和数据化的可视化。在这个文章中,全面解码看看自动化的极致状态为什么是可视化?在前面的另外一篇文章【运维平台全体系介绍】中,也讲到运维平台体系的构成,提出“**及服务”的理念,其中有几部分和自动化密切相关,比如说资源及服务、配置及服务、架构…

    2015-04-03

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-22 14:50

    写的很好,文字的排版还可以在漂亮一点,加油