第七周练习

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

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

  ~]# mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sda3

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

  ~]# mount -o noexec,noatime,acl /dev/sda3 /mydata

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

  ~]# mkswap device 开机自动启用:写在/etc/fstab文件中        DEVICE swap swap defaults 0 0

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

#!/bin/bash
cat <查看所有磁盘设备
按D>查看磁盘分区使用信息
按Q>退出
EOF
read -p ‘请按对应的字母键,否则五秒后自动退出’ -t 5 name
if [[ "$name" == "Q" ]];then
    echo "您选择退出";
    exit 1
elif [[ "$name" == "F" ]];then
    fdisk -l
elif [[ "$name" == "D" ]];then
    df -lh
else
    echo "您输入有误,请重启后再试"
fi

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

见另一篇博客

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

# mdadm -C  /dev/md#  -n 2 -l 1 -x 1 -c 128 /dev/sda{1,2,3}

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

#mdadm -C /dev/md# -a yes -n 3 -l 5  -c 256 /dev/sda{1,2,3}
#mkfs.ext4 /dev/md#
#mount  -o noatime,acl /dev/md# /backup

7、写一个脚本

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

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

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

#!/bin/bash
#
if [ $# -lt 1 ];then
    echo "At least one file path,try it again"
    exit 1
fi
for i in $*;do
    line=$(cat $i | wc -l)
    echo "$i文件的行数是$line"
done
echo "本次共统计$#个文件"

8、写一个脚本

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

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

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

#!/bin/bash
if [ $# -lt 2 ];then
    echo "At least two name,try it again please"
    exit 1
fi
for i in $*;do
    id $i &> /dev/null && exit 0 || useradd $i && echo $i | passwd --stdin $i
done
echo "共创建了$#个用户"

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

#!/bin/bash
#
sum=0
for i in {1..20};do
    id visitor$i &> /dev/null && echo "visitor$i已存在" && exit 0 || useradd visitor$i && echo "visitor$i创建成功"
done
for i in {1..20};do
    id=$(grep -E "visitor$i" /etc/passwd | cut -d: -f3)
    let sum+=$id
done
echo $sum

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

#!/bin/bash
#
num1=$(grep -E "#.*" $1 | wc -l)
num2=$(grep -E "#.*" $2 | wc -l)
num3=$(grep -E "#.*" $3 | wc -l)
empty1=$(grep -E "^[[:space:]]*$" $1  | wc -l)
empty2=$(grep -E "^[[:space:]]*$" $2  | wc -l)
empty3=$(grep -E "^[[:space:]]*$" $3  | wc -l)
let sum1=$num1+$num2+$num3
let sum2=$empty1+$empty2+$empty3
echo "#开头的行数之和是$sum1,空白行数之和是$sum2"

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

#!/bin/bash
#
awk -F: '$NF=="/bin/bash"{print $1,$3}' /etc/passwd
for i in $(grep -E ".*/bin/bash$" /etc/passwd | cut -d: -f3);do
    let sum+=$i
done
echo "UID之和是$sum"

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

#!/bin/bash
#
cat /etc/group | cut -d: -f1,4 | grep -E ".*:[^[:space:]]"
num=$(cat /etc/group | cut -d: -f1,4 | grep -E ".*:[^[:space:]]" | wc -l)
echo "共有此类用户$num个"

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

# vgcreate myvg -s 8M /dev/sdb1 /dev/sdc1
# lvcreate -L 5G -n mylv1 myvg
# mkfs.ext4 /dev/myvg/mylv1
# vim /etc/fstab
写入
/dev/mapper/myvg-mylv1  /users  ext4    defaults,acl            0 0

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

mkdir -pv /user/magedu
useradd -d /users/magedu magedu

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

# lvextend -L 9G /dev/myvg/mylv1

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

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

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

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

原创文章,作者:N24_涩味,如若转载,请注明出处:http://www.178linux.com/63151

(0)
N24_涩味N24_涩味
上一篇 2016-12-10
下一篇 2016-12-10

相关推荐

  • linux grep manual

    名称    grep – 打印匹配的行语法:     grep [option] pattern [file…]     grep [option] [-e pattern]…

    Linux干货 2015-08-31
  • 第七周作业

    查看作业内容请移步此链接:http://www.cnblogs.com/wangenzhi/p/6403568.html

    Linux干货 2017-02-15
  • 搜索引擎-处理查询

     我们从用户的角度来看,用户不关心什么索引结构是倒排还是签名文件,也不需要知道相关排序算法。用户提交了查询,就需要获取满意的搜索结果。这个搜索结果就是搜索引擎是否提供有效的服务。 1.查询流程 查询流程图: 1)用户提交查询 2)分析查询      查询预处理:    …

    Linux干货 2015-12-10
  • corosync+pacemaker+drbd+mysql来实现mysql的高可用和数据的同步

    实现拓扑图: 实验流程: 先对两主机安装上corosync和pacemaker 两主机安装drbd服务,并且设置好drbd的组设备 选择drbd主节点上,进行数据库的初始化 进行资源的定义和配置 测试 实验前,我们还需要做一些准备工作: 1、时间必须保持同步   使用ntp服务器 2、节点必须名称互相通信    解析节点名称 &…

    Linux干货 2015-11-10

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-14 13:51

    脚本的思路清晰,脚本需要考虑到无用的信息输出问题。