马哥教育网络班19期+第七周课程练习

1、创建一个10G分区,并格式为ext4文件系统;
   (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;

        mke2fs -b 2048 -m 2 -L 'MYDATA' -o defaults,acl

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

        mount -L 'MYDATA' -o noexec,nodiratime -t ext4 /data/mydata  
        
2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之;

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

        #!/bin/bash
        #
        i=1
        fdisk -l /dev/[s,h]d[a-z] | grep "Disk /"
        for DevName in $(ls /dev/[s,h]d[a-z][1-9]);do         
            if [ $i -eq 1 ] ;then
                df -h $DevName | awk -v OFS="    " '{print $1,$2,$3,$4,$5,$6}'
                let i++
            else
                df -h $DevName | grep -v "File" | awk -v OFS="    " -v name=$DevName '{print name,$2,$3,$4,$5,$6}'
            fi
        done

4、总结RAID的各个级别及其组合方式和性能的不同;
        RAID称为磁盘冗余阵列,用来提高磁盘耐用性以及IO能力
        大致常用组合分为以下几种:
        RAID 0 条带卷     读、写性能提升            可用空间:N*min(S1,S2,…)        无冗余能力    最少磁盘数:2, 2+
        RAID 1 镜像卷     读性能提升、写性能略下降    可用空间:1*min(S1,S2,…)        有冗余能力    最少磁盘数:2, 2+
        RAID 5             读、写性能提升            可用空间:(N-1)*min(S1,S2,…)    有冗余能力    最少磁盘数:3, 3+
        RAID-6:            读、写性能提升            可用空间:(N-2)*min(S1,S2,…)    有冗余能力    最少磁盘数:4, 4+
        RAID-10:        读、写性能提升            可用空间:N*min(S1,S2,…)/2    有冗余能力    最少磁盘数:4, 4+
        JBOD:            读、写性能无提升        可用空间:sum(S1,S2,…)        无冗余能力    最少磁盘数:1, 1+
        

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

    准备3个10G大小 标志位为fd 的硬盘分区 /dev/sdb1 /dev/sdc1 /dev/sdd1
    mdadm -C /dev/md0 -a yes -l 1 -n 2 -x 1 -c 128 /dev/sd{b,c,d}1
    
6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能;

    准备3个2G大小 标志位为fd 的硬盘分区 /dev/sdb2 /dev/sdc2 /dev/sdd2
    mdadm -C /dev/md1 -a yes -l 5 -c 256 -n 3 /dev/sd{b,c,d}2
    mke2fs -t ext4 /dev/md1
    echo "UUID=DeviceUUID /backup ext4 acl,nodiratime 0 0" >> /etc/fstab
    
7、写一个脚本
   (1) 接受一个以上文件路径作为参数;
   (2) 显示每个文件拥有的行数;
   (3) 总结说明本次共为几个文件统计了其行数;

    #!/bin/bash
    #
    declare -i fileNum=0
    echo
    for file in $* ;do
        if [ -f $file ];then
            echo $file: $(cat $file | wc -l)line
            let fileNum++
        else
            echo $file: No such file
        fi
    done
    echo -e "\n" "A total of $fileNum file"

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

    #!/bin/bash
    #
    declare -i userNum=0
    for userName in $* ;do
        if id $userName &>/dev/null ;then
            echo "$userName already exist!"
        elif useradd $userName &>/dev/null ;then
            echo $userName | passwd –stdin $userName &>/dev/null
            let userNum++
            echo "$userName creat!"
        else
            echo "$userName can't creat!"
        fi
    done
    echo "Creat $userNum users"

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

    #!/bin/bash
    #
    declare -i idSum=0
    for ((i=1;i<21;i++));do
            if id visitor$i &>/dev/null ;then
                    let idSum+=$(cat /etc/passwd | grep ^visitor$i | cut -d: -f3)
            else
                    useradd visitor$i
                    let idSum+=$(cat /etc/passwd |tail -1 |cut -d: -f3)
            fi
    done

    echo "idSum: $idSum"

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

    #!/bin/bash
    #
    file1="/etc/fstab"
    file2="/etc/rc.d/rc.sysinit"
    file3="/etc/rc.d/init.d/functions"
    for file in {$file1,$file2,$file3};do
        echo -n "$file: " ;awk '/^#/{i++}END{print i,"Line"}' $file
    done
    echo -n "Space Line: " ; awk '/^$/{i++}END{print i,"Line"}' $file1 $file2 $file3

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

    #!/bin/bash
    #
    awk -F: '/bash$/{printf "User:%-10s Uid:%i\n",$1,$3}' /etc/passwd
    awk -F: '/bash$/{idSum+=$3}END{print "IdSum: "idSum}' /etc/passwd

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

    #!/bin/bash
    #
    declare -a userName
    declare -i userNum
    userName=$(cat /etc/passwd | cut -d: -f1)
    for u in $userName ;do     
        id -G $u | awk -v name=$u '{if (NF>1) {print name}}'  
        n=$(id -G $u | wc -w )
        if [ $n -gt 1 ];then
        let userNum++
        fi
    done
    echo "User is $userNum"

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

    用fdsik 创建2个总和为20G的物理分区 sdb1 sdc1 卷标为8e
    mkdir /users
    pvcreate /dev/sd{b,c}1
    vgcreate -s 8M vgtest /dev/sd{b,c}1
    lvcreate -L 5G -n mylv1
    mke2fs -t ext4 /dev/vgtest/mylv1
    echo "/dev/vgtest/mylv1       /users  ext4    defaults,acl    0       0" >> /etc/fstab
    init 6

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

    useradd -b /users magedu
    su – magedu
    cp /etc/m* ./
15、扩展mylv1至9G,确保扩展完成后原有数据完全可用;

    lvextend -L 9G /dev/vgtest/mylv1
    resize2fs /dev/vgtest/mylv1
    
16、缩减mylv1至7G,确保缩减完成后原有数据完全可用;

    umount /users
    e2fsck -f /dev/vgtest/mylv1
    resize2fs /dev/vgtest/mylv1 7G
    lvreduce -L 7G /dev/vgtest/mylv1
    mount /dev/vgtest/mylv1 /users
    
    
17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息;

    lvcreate -s -L 512M -n mylv-snap -p r /dev/vgtest/mylv1

原创文章,作者:N23_夕立时雨,如若转载,请注明出处:http://www.178linux.com/18942

(0)
N23_夕立时雨N23_夕立时雨
上一篇 2016-06-20
下一篇 2016-06-21

相关推荐

  • n25 第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。   2、取出最后登录到当前系统的用户的相关信息。   3、取出当前系统上被用户当作其默认shell的最多的那个shell。   4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxus…

    Linux干货 2016-12-20
  • bash进阶学习ing

    使用read命令来接受输入使用read来把输入值分配给一个或多个shell变量: -p 指定要显示的提示 -t TIMEOUT read 从标准输入中读取值,给每个单词分配一个变量所有剩余单词都被分配给最后一个变量read -p “Enter a filename: “ FILE 条件选择if语句选择执行:注意: if语句可嵌套单分支if 判断条件: the…

    Linux干货 2016-08-21
  • 堡垒机-麒麟开源堡垒机内置SSL VPN使用指南

      一、安装 (一)确定服务器的操作系统位数 Windws xp、2000、2003系统,在我的电脑属性里,可以很明显地看到标识。如果没有注明是64位的,那么默认就是32位的 Windows 7 系统在控制面板,点击系统,在系统类型里,标注有操作系统位数 (二)安装VPN客户端 VPN客户端分为32位系统和64位系统二…

    Linux干货 2016-05-29
  • OpenSSL

    三个组件: openssl: 多用途的命令行工具; libcrypto: 加密解密库; libssl:ssl协议的实现; PKI:Public Key Infrastructure CA RA CRL 证书存取库  建立私有CA: OpenCA openssl  证书申请及签署步骤: 1、生成申请请求; 2、RA核验; 3、CA签署; 4…

    Linux干货 2015-03-21
  • DNS快速入门、正反向解析……

    DNS服务原理详解 因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析。 我们在访问一个网站的时候,只要输入该网站的网址就会跳转到该网站页面,而实现这一过程就需要DNS服务器将域名解析为IP地址,进而实现数据通信。 DNS:…

    2017-06-03
  • RPM程序包管理器及其前端工具YUM

    RPM:     RPM,Redhat Package Manager,RPM is Package Manager 功能:将编译好的应用程序的各组成文件打包一个或几个程序包文件,从而方便快捷地实现程序包的安装、卸载、查询、升级和校验等管理操作 1)RPM包的命名 2)RPM包文件的组成   &nb…

    Linux干货 2016-08-21

评论列表(1条)

  • 马哥教育
    马哥教育 2016-06-23 14:22

    写的很棒,可以关注一些排版的技巧,那样会更完美