马哥教育网络班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

相关推荐

  • 基于ssl协议和openssl工具建立私有CA

    前言     要自建CA需先了解openssl工具和ssl协议还有各加密类型     ssl(Secure Socket Layer)安全套接字层当前版本为3.0,浏览器与Web服务器之间的身份认证和加密数据传输,它工作在传输层和各应用层之间,用户可以选择是否使用ssl进行传输,选择ssl协议将调用…

    Linux干货 2015-05-07
  • class-7 积累应用

    1、当天课程内容笔记 2、当天练习 3、预习 4、取本机ip地址 [root@6 ~]#  ip addr|egrep -o '(\b([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\b\.)(\b([1-9]|[1-9][0-9]|1[0-…

    Linux干货 2016-08-08
  • 使用tar打包并使用gzip压缩的shell脚本应用实验

    博客目的: 练习find,gzip,tar,grep,vim等命令的使用以及shell脚本的初步使用 命令行模式下: 1、find出/目录下100M以上的文件并且查看 [root@rookie ~]# find / -size +100M | xargs ls -lh -r——–. 1 root root 128T 4月 8 16:02 /proc…

    Linux干货 2017-04-09
  • N25-第一周 总结

    一、描述计算机的组成及其功能     CPU:包括运算器、控制器、寄存器、缓存,计算枢纽,网络的包处理、磁盘读写、数学计算等。     内存:加载数据,提高计算速度,程序被加载到内存成为进程运行。     输入:键盘、鼠标     输出:打印机、显示器 二、按系列罗列linux的…

    Linux干货 2016-12-05
  • 0811:脚本练习

    系统信息获取脚本 1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。 [root@centos7 scripts]#cat systeminfo.sh  #!/usr/bin/bash  server_ip…

    Linux干货 2016-08-22
  • 网络班22期学习宣言

    马哥Linux运维学院 学习宣言 亲爱的小伙伴:        欢迎大家报名马哥Linux运维网络学习班,跟随马哥学习Linux技术,成就Linux大牛之梦。在这里,我们不仅可以学习到最优秀的技术课程,还可以跟着追梦的小伙伴们一起学习、一起进步。 为了督促大家一直积极认真努力的学习,请各位同学在评论区写出你的学习宣言。…

    Linux干货 2016-08-03