第七周 N21 总有刁民想害朕

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

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

       mke2fs -t ext4 /dev/sdb5 -b 2048 -m 2 -L "MYDATA"

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

       mount -o noexec -o acl -o nodiratime /dev/sdb5 /MYDATA 

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

       fdis创建一个分区,改id为82,然后mkswap /DEVICE   使用swapon /DEVICE 挂载

3、写一个脚本

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

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

    #!/bin/bash

         for i in `fdisk -l /dev/[hs]d*| egrep "^/dev/[hs]d*" | cut -d" " -f1`;do

            df -h $i

         done

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

R0  sprite 将2个以上物理设备线性集合成一起

R1  mirror 2+,其中一个完全同步另一个的磁盘数据

R5  3盘+,每盘都有部分数据和 checksum 例如 第一块的chunk1 第二块的chunk1存储数据,第三块的chunk1存储第一盘第二盘chunk1的的checksum

    然后第一块存储第二块 第三块上chunk2的checksum,第二块 第三块盘的chunk2 存储数据,依次类推

R6  4盘+,有2块校验盘

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

(1)创建分区 

(2)内核重读分区表 partx -a 内核重读分区表 

(3)以mdadm创建RAID mdadm -C /dev/md0 -n 2 -c 128k -l 1 -x 1 -a yes /dev/sdb{8,9,10}

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

      mke2fs -t ext4 -c 256k

      mount -o noexec,nodiratime,acl /dev/sdb1 /data/mydata

7、写一个脚本

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

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

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

   #!/bin/bash

     #

     if  [ $# -lt 1 ],then

      echo " as least 1",

      fi

      for i in $@;do

      wc -l $i

      done

8、写一个脚本

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

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

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

     #!/bin/bash

     #

        if [ $# -lt 2 ] ;then

        echo " has least 2"

      fi

        for i in $@;do

         id $i &>/dev/null

        if [ ! $? -eq 0 ];then

          useradd $i && echo "$i" | passwd $i  –stdin | wc -l | tee /tmp/aa.out &>/dev/null

        else

          echo "user has exists"

        fi

        done

        cat /tmp/aa.out

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

       

      #!/bin/bash

         #

       sum=0

              for i in {1..20};do

              id visitor$i

              if [ ! $? -eq 0 ];then

              useradd visitor$i

              else

                echo "visitor$i has exist"

         

              for i in `egrep "^visitor"  /etc/passwd | cut -d":" -f3`;do

              let sum+=$sum + $i

              done

              echo $sum

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

         #!/bin/bash

         #

         for file in /etc/rd.d/rc/sysinit /etc/rc/d/init.d/functions /etc/inittab;do

              echo "$file is `egrep "^#" $file | wc -l`lines"

              echo "$file is `egrep "^$" $file | wc -l`null"

         done

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

            sum=0

            for i in `egrep "bash$" /etc/passwd | cut -d":" -f3`;do

            let sum+=$i

            done

            echo $sum                

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

for i in "egrep `cat /etc/group | cut -d":" -f3`"

  [ -n "$i" ] && 

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

新建pv 

[root@localhost ~]#pvcreate /dev/sdb{1,2}

创建VG 

[root@localhost ~]#vgcreate  -s 8M myvg666 /dev/sdb{1,2} 

新建LV 

[root@localhost ~]#lvcreate -L 5G -n mylv666 myvg666 

格式化 

[root@localhost ~]#mkfs -t ext4 /dev/myvg666/mylv666

设置自动挂载 

[root@localhost ~]#mkdir /test 

echo "/dev/myvg666/mylv666 /test ext4 defaults,acl 0 0" >> /etc/fstab

   

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

   useradd magedu  -d /users/magedu 

   su – magedu

   cp /etc/passwd /etc/fstab /users/magedu

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

lvextend -L +4G /dev/vg666/mylv666

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

umount /lvm/test

e2fsck /dev/vg666/lv666

resize2fs /dev/vg666/lv666 7G

lvreduce -L 7G /dev/vg666/lv666

mount /dev/vg666/lv666 /lvm/test

查看其中的文件可用性

(取消挂载,强制检查、缩减文件系统、缩减lv、重新挂载)

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

lvcreate -L 2G -s -n lv666back/dev/vg666/lv666

原创文章,作者:N21-总有刁民想害朕,如若转载,请注明出处:http://www.178linux.com/27109

(0)
N21-总有刁民想害朕N21-总有刁民想害朕
上一篇 2016-08-08
下一篇 2016-08-08

相关推荐

  • 软件包管理

      软件运行环境       API:Application Programming Interface         POSIX :Portable OS      码程序源代码 –>预处理 –> 译…

    Linux干货 2016-08-29
  • nmcli命令用法简介

    nmcli:地址配置工具 用法:nmcli [OPTIONS] OBJECT { COMMAND | help } 一般使用的情况有: 设备:正在使用的网络端口 链接:一组配置设置,对于一个单一的设备可以有多个连接,可以在链接之间切换 常用命令:     nmcli connection show &nbsp…

    Linux干货 2016-09-07
  • raid5创建

    创建分区并改类型 创建raid5   创建把文件系统 生成配置文件    

    2017-12-17
  • 文本处理工具

    cat:查看文本文件  tac:竖行相反  rav:行内相反 -n:显示时加行号(空行也加行号) -b:            (空行不加) more:分页查看文件 -d:显示翻页及退出提示 less:一页一页查看文件或STDIN输出 head:前 -n#:前#行内容 tail:…

    Linux干货 2016-08-08
  • 推荐-内核虚拟化技术——LXC初体验

    一、Cgroups 1.1 介绍 Cgroup是Control group的简称。最初由由Google的工程师(主要是Paul Menage和Rohit Seth)在2006年以“process containers(进程容器)”的名字开始的, 在2007年的晚些时候被重命名为“控制组”并被合并到了2.6.24版的内核中,现已成为Linux内核中的一个功能,…

    Linux干货 2016-03-31
  • 搭建私有CA服务器

       CA(Certificate Authority)证书颁发机构主要负责证书的颁发、管理以及归档和吊销。证书内包含了拥有证书者的姓名、地址、电子邮件帐号、公钥、证书有效期、发放证书的CA、CA的数字签名等信息。证书主要有三大功能:加密、签名、身份验证。下面来看一下自建CA的过程    一、建立CA服务器 &nbsp…

    Linux干货 2016-03-14

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-08 16:54

    写的很好,排版还可以在漂亮一点,加油,10 12 不对,在好好想想