马哥教育网络班N22期+第7周课程练习

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

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

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

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

mount -o noatime,noauto /dev/sdb1 /data/mydata

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

fdisk /dev/sdb
n
p2+1G
t82w
mkswap /dev/sdb2 
swapon /dev/sdb2

3、写一个脚本

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

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

#!/bin/bashfor i in `blkid | cut -d: -f1`;do
    echo $i
    df -h $idone

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

屏幕快照 2016-10-17 13.01.15屏幕快照 2016-10-17 13.01.15.png
此图源自:维基百科

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

mdadm -C /dev/md0 -l1 -c128 -n2 -x1 /dev/sdb{1,2,3}

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

准备3块2G的磁盘分区,并格式化为ext4的格式:/dev/sdb{5,6,7}

mdadm -C /dev/md1 -n3 -l5 -c256 /dev/sdb{5,6,7}
mkfs.ext4 /dev/md1

vim /etc/fstab添加一行

/dev/md1 /backup ext4 defaults,acl,noatime 0 0

7、写一个脚本

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

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

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

#!/bin/bashdeclare -i sumdeclare -i fsum
sum=0fsum=0read -p "input filepath:" -a path
file_arg=${#path[*]}for i in `seq 0 $[${file_arg}-1] ` ;do
  echo "i=$i"
  if [ -e ${path[$i]} -a -f ${path[$i]} ] ;then
    fline=$(wc -l ${path[$i]}| cut -d' ' -f1)    echo "${path[$i]} lines is ${fline}"
    let sum=$sum+$fline
        let fsum+=1
  else
    echo "${path[$i]} is not file"
  fi
  echo "file number is $fsum ,sumlines $sum"done

8、写一个脚本

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

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

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

#!/bin/bashdeclare -i argnumread -p "input username:" -a u_name
argnum=${#u_name[*]}for i in `seq 0 $[$argnum-1]`;do
        useradd ${u_name[$i]}
        echo ${u_name[$i]} | passwd --stdin ${u_name[$i]} >/dev/nulldone
        echo "adduser count : $argnum "~

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

#!/bin/bashdeclare -i uiddeclare -i sum
sum=0for i in {1..20};do
  useradd visitor$i
  uid=$(id -u visitor$i)  let sum=$sum+$uiddone
  echo "uidsum is $sum"~

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

#!/bin/bash
 sum=$(sed -n '/^[#]/ p' /etc/rc.d/rc.sysinit | wc -l) echo $sum
 sum2=$(sed -n '/^[#]/ p' /etc/rc.d/init.d/functions | wc -l)  echo $sum2
 sum3=$(sed -n '/^[#]/ p' /etc/fstab | wc -l)  echo $sum3sumspace=$(sed -n '/^$/ p' /etc/rc.d/rc.sysinit /etc/fstab /etc/rc.d/init.d/functions| wc -l)  echo "space conut: $sumspace"

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

#!/bin/bashdeclare -i sum
sum=0sed -n '/bash$/p' /etc/passwd | cut -d: -f1,3for i in `sed -n '/bash$/p' /etc/passwd | cut -d: -f3`;do
        sum+=$idone
   echo "uidsum:$sum"

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

#!/bin/bashdeclare -i sum
sum=0while read lines;do
  username=$(echo $lines | cut -d: -f1)  if [ `id -G $username | wc -w` -ge 2 ];then
        sum+=1
        echo $username
   fidone</etc/passwdecho "user number : $sum"

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

创建4个大小为5G的分区:/dev/sd{b,c,d,e}1,使用fdisk的子命令-t变更分区id为8e。
1.创建PV

lvcreate /dev/sd{b,c,d,e}1



2.创建VG

vgcreate -s 8M myvg /dev/sd{b,c,d,e}1



3.创建带下为5G的逻辑卷mylv1

lvcreate -L 5G -n mylv1 myvg



4.格式化ext4文件系统

mkfs.ext4 /etc/mapper/myvg-mylv1



5.开机自动挂载
vim /etc/fstab

/etc/mapper/myvg-mylv1 /users ext4 defaults,acl 0 0


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

useradd -d /users/magedu magedusu -l magedu
cp /etc/fstab /etc/rc.d/rc.sysinit ~

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

resize2fs /etc/myvg/mylv1 9G

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

缩减文件系统容量

umount /users
resize2fs /dev/myvg/mylv1 7G



缩减lv容量

lvreduce -L 7G /dev/myvg/mylv1


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

lvcreate -s -n snapshot -L 512M /dev/myvg/mylv1

原创文章,作者:N22-武汉-enfp,如若转载,请注明出处:http://www.178linux.com/52377

(0)
N22-武汉-enfpN22-武汉-enfp
上一篇 2016-10-24 09:11
下一篇 2016-10-24 09:11

相关推荐

  • CA和证书

    A与B双方通信,需要通过签证机构CA颁发证书,才可以互相信任,从而安全的进行数据传输。想要获取证书,除了付费购买认证机构的证书,还可以自签名获取证书。 openssl命令可以搭建CA,实现自签名证书。下面以三台主机为例,模拟根CA、子CA的搭建,以及客户端申请证书的过程。 一、搭建根CA /etc/pki/tls/openssl.cnf文件是openssl的…

    2017-09-10
  • 计算机简介

    计算机的简介 电子计算机(英语:computer),亦称电脑,是一种利用「电子学」原理,根据一系列指令对数据进行处理的工具计算机种类繁多,但实际来看,计算机总体上是处理信息的工具。计算机在组成上形式不一,早期计算机的体积足有一间房屋的大小,而今天某些嵌入式计算机可能比一副「扑克牌」还小。当然,即使在今天依然有大量体积庞大的巨型计算机为特别的[科学]计算或面向…

    Linux干货 2016-10-28
  • Shell中的循环语句

    在编程语言中,循环语句是最基本的语法之一,在Shell(这里是Bash)中也不例外。把相关内容整理一下吧。 这里包括for/while/until循环,以及变量自增的语法实例。 Shell(以Bash为例)中的循环语句一般有for、while、until这几种,偶尔还有写错语法的时候,这里结合实例来自己总结一下。也为今后使用提供一个快捷的资料获取渠道。 一、…

    Linux干货 2016-08-22
  • X86平台系统启动流程 (Blog 9)

    POST –> BootSeqence(BIOS) –> Bootloader(MBR) –> Kernel(initrd) –> init(/etc/inittab)

    2017-11-27
  • Linux命令date命令详解

    在linux环境中,熟练运用date命令来表示自己想要表示的时间,肯定可以给自己的工作带来诸多方便,下面是详细的使用说明和示例 在linux环境中,不管是编程还是其他维护,时间是必不可少的,也经常会用到时间的运算,熟练运用date命令来表示自己想要表示的时间,肯定可以给自己的工作带来诸多方便。 1.命令格式:date[参数]… [+格式] 2.命…

    2017-07-18
  • linux 磁盘管理

    磁盘管理 Linux思想一切皆文件: open(),read(),write(),close() I/O 设备地址 设备类型: 块设备:block,存取单位“块”,磁盘 (随机访问) 字符设备:char,存取单位“字符”,键盘 (逻辑访问) 设备文件:关联至一个设备驱动程序,进而能够跟与之对应硬件设备进行通讯。 设备编号: ll /dev/sda* root…

    Linux干货 2016-08-29