第七周练习

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

相关推荐

  • Zabbix基于Proxy分布式部署实现Web监控

    前言 在日常运维工作中,难免会遇到这样或那样的故障,如何能在第一时间发现故障,并及时定位故障原因,保证业务不受影响,我想这应该是做好一个运维必须要掌握的技能。但人力不可能实时掌控系统的变化,于是监控系统应运而生,监控便是运维的眼睛,把监控和性能管理做好后,运维就是一件很轻松的事情。目前比较流行的开源监控工具有Cacti、Nagios(Icinga)、Zabb…

    Linux干货 2015-07-13
  • 08-vim文本编辑器

    简介: vi: Visual Interface,文本编辑器 文本:ASCII, Unicode 文本编辑种类: 行编辑器: sed 全屏编辑器:nano, vi vim – Vi Improved 其他编辑器: gedit 一个简单的图形编辑器 gvim 一个Vim编辑器的图形版本 打开文件: # vim [OPTION]… FIL…

    2017-03-16
  • N25第二周视频作业:用户、组与权限管理详解

    此篇博客是根据视频要求写的,因为马哥在视频中说了,用户组、权限在linux运维过程中比较重要,所以一定要深入学习 首先,先介绍一下用户、组与权限是什么:     用户:用户时指你在服务器上的标识,通过不同类型的用户,你享受到不同的待遇,而待遇就是权限的大小。每个用户在服务器上都有唯一的id标识,即使你将此用户删除,再建…

    Linux干货 2016-11-26
  • vim简单实用的技巧总结

    vi 和 vim无需过多的区分,vim可认为是vi的增强版。        这篇关于vim的手册,我个人觉得实在无法把它写成文章,只能以手册的方式列举出来,因为,vim是一个动手使用的工具,只能在使用中你才能慢慢发现它的操作多么符合逻辑,我从下面这些简略的描述中,尽量将它的操作步骤写出来,但更重要的…

    Linux干货 2015-09-14
  • Mariadb数据库复制系列(二):主主复制

       实验二:MySQL双主复制架构的实现 双主的实现方式与主/从类似,仅是两个主机即使主节点,又是对方的从节点双主模型容易造成数据的不一致性,因此要慎用! 1、实验环境 2、在两个节点上安装mariadb-server服务 3、修改两个节点的服务器配置文件 4、两个节点上各自启动服务,各授权一个具有复制权限的用户 5、查看两个节点的二进制日志的状态 6、在…

    Linux干货 2016-11-24
  • Linux Service and Security(Part 1)

    一、知识整理 1、不安全的传统协议: telnet、FTP、POP3等:不安全的密码; http、smtp、NFS等:不安全信息; Ldap、NIS、rsh等:不安全验证。 设计基本原则: 使用成熟的安全系统; 以小人之心度输入数据; 外部系统是不安全的; 最小授权; 减少外部接口; 缺省使用安全模式; 在入口处检查; 安全不是似是而非; 从管理上保护好系统…

    Linux干货 2016-10-09

评论列表(1条)

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

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