N22-第七周作业

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

# fdisk /dev/sda
n
p
3
w
# partx -a /dev/sda 
# partx -a /dev/sda
# mke2fs -t ext4 -b 1024 -L "MYDATA" -m 2 /dev/sda3

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

    # mke2fs -t ext4 -b 1024 -L "MYDATA" -m 2 /dev/sda3

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

mount -o noatime,noexec,acl /dev/sda3 /data/mydata

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

# fdisk /dev/sda
n
e
选择使用全部空间
n
t
5
82
w
# partx -a 
# partx -a 
# mkswap /dev/sda5
# swapon /dev/sda5
# free -m

3、写一个脚本

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

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

#!/bin/bash
#
fdisk -l /dev/sd[a-z]|grep -o "^Disk /dev/sd[a-z]"|awk '{print $2}'
df -lh|awk '/^\/dev\//{print $1,$5}'

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

RAID0
    读、写性能提升;
    可用空间:N*min(S1,S2,...)
    无容错能力
    最少磁盘数:2, 2+
RAID1
    读性能提升、写性能略有下降;
    可用空间:1*min(S1,S2,...)
    有冗余能力
    最少磁盘数:2, 2+
RAID-5:
    读、写性能提升
    可用空间:(N-1)*min(S1,S2,...)
    有容错能力:1块磁盘
    最少磁盘数:3, 3+
RAID-6:
    读、写性能提升
    可用空间:(N-2)*min(S1,S2,...)
    有容错能力:2块磁盘
    最少磁盘数:4, 4+
    混合类型
RAID-10:
    读、写性能提升
    可用空间:N*min(S1,S2,...)/2
    有容错能力:每组镜像最多只能坏一块;
    最少磁盘数:4, 4+
RAID-01:
    读、写能力提升
    可用空间:N*min(S1,S2,...)/2
    有容错能力:每组镜像最多可坏三块;
    最少磁盘数:4, 4+
JBOD:Just a Bunch Of Disks
    功能:将多块磁盘的空间合并一个大的连续空间使用;
    可用空间:sum(S1,S2,...)

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

# 首先创建这三个分区,/dev/sdb1 /dev/sdc1 /dev/sdd1

# mdadm -C /dev/md0 -n 2 -l 1 -c 128 -x 1 /dev/sdb1 /dev/sdc1 /dev/sdd1

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

首先创建3个2G分区,/dev/sdb1 /dev/sdc1 /dev/sdd1
# mdadm -C /dev/md1 -n 3 -l 5 -c 256 /dev/sdb2 /dev/sdc2 /dev/sdd2mke2fs -t ext4 /dev/md1
# vim /etc/fstab
# /dev/md1              /backup                 ext4    noatime,acl     0 0

7、写一个脚本

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

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

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

#!/bin/bash
#
declare -i m=0
if [ $# -lt 1 ];then
echo "least one path by given"
exit 1
fi
for i in $*;do
if [ -e $i ];then
echo "the lines of $i is `wc -l $i|awk '{print $1}'`"
let m=$m+1
else
echo "no $i file,we will no count this file"
fi
done
echo "the number of count is $m"

8、写一个脚本

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

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

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

#!/bin/bash
#
declare -i count=0
if [ $# -lt 2 ];then
echo "para is less"
exit 1·
fi
for i in $*;do
if id $i&> /dev/null;then
echo "user exit"
continue
else
useradd $i >/dev/null
echo "$i"|passwd --stdin $i >/dev/null
let count=$count+1
fi
done
echo "sum of useradd is $count"

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

#!/bin/bash
#
declare -i sum=0
for i in `seq 1 1 20`;do
if id visitor$i&> /dev/null;then
echo "visitor$i already exit"
count=`id -u visitor$i`
let sum=$sum+$count
continue
else
useradd visitor$i
count1=`id -u visitor$i`
let sum=$sum+$count1
fi
done
echo "the sum id is $sum"

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

#!/bin/bash
#
declare -i count
count1=`cat /etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab|grep "^#" |wc -l`
count2=`cat /etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab|grep "^$" |wc -l`
echo -e "The sum of lines is $count1\nThe sum of black lines is $count2"

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

#!/bin/bash
#
declare -i sum=o
awk -F: '/\/bin\/bash$/{print $1,$3,$7}' /etc/passwd
# awk -F: '{if($NF=="/bin/bash")print $1,$3,$7}' /etc/passwd 
# awk -F: '/\/bin\/bash$/{printf "USERNAME:%s,UID:%s,SHELL:%s",$1,$3,$7}' /etc/passwd
sumid=`awk -F: '/\/bin\/bash$/{print $1,$3,$7}' /etc/passwd|awk '{print $2}'`
for i in $sumid;do
let sum=$i+$sum
done
echo "All userid sum:$sum"

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

#!/bin/bash
#
declare -i count=0
for i in `awk -F: '{print $1}' /etc/passwd`;do
    [ -z `id $i|awk -F',' '{print $2}'|awk -F'(' '{print $2}'|awk -F')' '{print $1}'` ] || echo -e "$i\n" && let count=$count+1
done

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

# fdisk /dev/sda
n
+10G
t
5 
8e
w 
以上步骤执行两次
# partx -a /dev/sda
# partx -a /dev/sda
# pvcreate /dev/sda{6,7}
# pvs
# vgcreate -s 20G myvg
# vgs
# lvcreate -L 5G -n mylv1 myvg
# lvs
# vim /etc/fstab
/dev/myvg/mylv1/usersext4defaults,acl0 0 
# mount -a
# df -lh 验证是否挂载成功

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

# useradd -d /users/magedu magedu
# su magedu
# cp /etc/{passwd,fstab} /users/magedu

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

# lvexpand -L 9G /dev/myvg/mylv1
# resize2fs /dev/myvg/mylv1 9G

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

# umount /dev/myvg/mylv1
# e2fsck -f /dev/myvg/mylv1
# resize2fs /dev/myvg/mylv1 7G
# lvreduce -L 7G /dev/myvg/mylv1 
# mount -a

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

# lvcreate -s -L 7G -p r -n snapmylv1 /dev/myvg/mylv

原创文章,作者:N22-北京-喜欢就好,如若转载,请注明出处:http://www.178linux.com/49766

(0)
N22-北京-喜欢就好N22-北京-喜欢就好
上一篇 2016-10-09
下一篇 2016-10-09

相关推荐

  • 第一周学习内容

    1、LINUX的三大主流版本:debian slackware redhat 2、一个完整的操作系统是由内核+运行在内核之上的应用程序组成。      LINUX操作系统是由linux内核+GNU开源组织编写的应用程序组成(GNU/Linux) 3、CPU架构:X86(X64)、摩托罗拉的m68k、arm、IBM的POWER(性…

    Linux干货 2016-12-03
  • 文件查找locate和find

    locate 查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db 依赖于事先构建的索引 索引的构建是在系统较为空闲时自动进行(周期性任务),管理员手动更新数据库(updatedb) 索引构建过程需要遍历整个根文件系统,极消耗资源 工作特点: •查找速度快 •模糊查找 •非实时查找 •搜索的是文件的全路径,不仅仅是文件名 •…

    2017-08-11
  • 马哥教育网络班N22期+第7周作业

    1、创建一个10G分区,并格式为ext4文件系统;(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;mke2fs -t ext4 -b 2048 -L MYDATA -m 2 /dev/sdb1tune2fs -o acl /dev/sdb1(2) 挂载至/data/mydata目录,要求挂载时禁止…

    Linux干货 2016-11-14
  • vim的简单应用

    vim的简单应用         之前我们学习过Linux的思想,其中有一条就是一切皆文本,所以在这里大部分配置文件都是文本模式存在的,那么使用简单的文字编辑器就可以修改配置了,之前我们学习过nano文本编辑器,但是Vim会比nano使用的更为方便,也更强大。 基本现在所有的Li…

    2017-06-17
  • CentOS系统启动流程–上

    centos6启动流程 1.加载BIOS的硬件信息,获取第一个启动设备。 2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息 3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱 动所有的硬件设备。 4.核型执行init程序并获取运行信息。 5.Init执行/etc/rc.d/rc.sysinit文件。 6.启动核心的外挂模块(/etc/m…

    Linux干货 2016-09-13
  • N25第5周作业(grep和find使用)

    显示当前系统上root, fedora 或user1的默认shell 找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello(); 使用echo命令输出一个绝对路径,使用grep取出基名,扩展取出其路径名 找出IFCONIFG命令结果的1-255之间的数字 挑战题:写一个模式,能匹配出合理的IP地址 挑战题…

    Linux干货 2016-12-30

评论列表(1条)

  • luoweiro
    luoweiro 2016-10-11 23:32

    对于raid相关的基础知识希望掌握熟练,这部分可以做成一个表格,以后时不时翻出来看看,也会更加直观。