第七周练习

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 16:58
下一篇 2016-12-10 20:03

相关推荐

  • Linux文件和目录管理类命令初识

    简述 在Linux操作系统使用过程中,因为运维需要频繁的对文件、目录进行操作,所以需要学习一些关于文件、目录的命令 Linux上文件是什么? 「文件」:存储空间存储的一段流式数据,可以按名「存取」这些数据 常见文件类型 -:常规文件d:目录文件b:块设备文件,以「block」为单位进行随机访问,常见设备「硬盘」c:字符设备文件,以「character」为单位…

    Linux干货 2016-11-06
  • 数据结构- 串的模式匹配算法:BF和 KMP算法

    Brute-Force算法的思想 1.BF(Brute-Force)算法   Brute-Force算法的基本思想是: 1) 从目标串s 的第一个字符起和模式串t的第一个字符进行比较,若相等,则继续逐个比较后续字符,否则从串s 的第二个字符起再重新和串t进行比较。 2) 依此类推,直至串t 中的每个字符依次和串s的一个连续的字符序列相等,则称模式匹…

    Linux干货 2015-04-07
  • case条件判断语句

    条件判断: case语句     在shell编程中,对于多分支判断,用if 虽然也可以实现,但有些时候,写起来很麻烦,也不容易代码理解。这个时候,可以考虑case。 case 变量引用 in PAT1) 分支1 ;; PAT2) 分支2 ;; … *) 默认分支 ;; esac case语句结构特点如下:…

    Linux干货 2016-08-16
  • Linux部分命令及通配符用法

    pwd: 显示工作目录 cd -: 在上一次所在目录与当前目录之间来回切换 cd: 切换回家目录 cat:  文本查看工具 n:给显示的文本行编号 -E:显示行结束符$ passwd 修改用户的密码 which 查看系统命令所对应的路径 df 查看系统分区 runlevel 查看系统运行级别  (共有6个级别) Tty…

    2017-03-28
  • Nginx代理MogileFS并实现负载均衡和高可用

    Nginx代理MogileFS并实现负载均衡和高可用 MogileFS nginx 负载均衡 前言 实验拓扑 实验环境 实验步骤 配置MogileFS 配置Nginx 总结 前言 上篇文章我们了解分布式系统和MogileFS的基本使用, 但是那样的架构是有问题的, 本篇文章我们来了解一下如何使用nginx-mogilefs-module-…

    大数据运维 2016-05-05
  • N22-第九周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i log_user declare -i notlog_user while read&n…

    Linux干货 2016-10-24

评论列表(1条)

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

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