1.创建一个10G的分区,并格式为ext4的文件系统;
(1)要求其block大小为2048,预留空间百分比为2,卷标为MYDATA,默认挂载属性包含acl;
# fdisk /dev/sdb 欢迎使用 fdisk (util-linux 2.23.2)。 更改将停留在内存中,直到您决定将更改写入磁盘。 使用写入命令前请三思。 Device does not contain a recognized partition table 使用磁盘标识符 0x41f06c54 创建新的 DOS 磁盘标签。 命令(输入 m 获取帮助):p 磁盘 /dev/sdb:42.9 GB, 42949672960 字节,83886080 个扇区 Units = 扇区 of 1 * 512 = 512 bytes 扇区大小(逻辑/物理):512 字节 / 512 字节 I/O 大小(最小/最佳):512 字节 / 512 字节 磁盘标签类型:dos 磁盘标识符:0x41f06c54 设备 Boot Start End Blocks Id System 命令(输入 m 获取帮助):n Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): p 分区号 (1-4,默认 1):1 起始 扇区 (2048-83886079,默认为 2048): 将使用默认值 2048 Last 扇区, +扇区 or +size{K,M,G} (2048-83886079,默认为 83886079):+10G 分区 3 已设置为 Linux 类型,大小设为 10 GiB 命令(输入 m 获取帮助):w The partition table has been altered! Calling ioctl() to re-read partition table. 正在同步磁盘。 # mkfs.ext4 -b 2048 -m 2 -L MYDATA /dev/sdb1 mke2fs 1.42.9 (28-Dec-2013) 文件系统标签=MYDATA OS type: Linux 块大小=2048 (log=1) 分块大小=2048 (log=1) Stride=0 blocks, Stripe width=0 blocks 655360 inodes, 5242880 blocks 104857 blocks (2.00%) reserved for the super user 第一个数据块=0 Maximum filesystem blocks=273678336 320 block groups 16384 blocks per group, 16384 fragments per group 2048 inodes per group Superblock backups stored on blocks: 16384, 49152, 81920, 114688, 147456, 409600, 442368, 802816, 1327104, 2048000, 3981312 Allocating group tables: 完成 正在写入inode表: 完成 Creating journal (32768 blocks): 完成 Writing superblocks and filesystem accounting information: 完成 # tune2fs -o acl /dev/sdb1 tune2fs 1.42.9 (28-Dec-2013)
(2)挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;
# mkdir -p /data/mydata # mount -o noatime,noexec /dev/sdb1 /data/mydata
2.创建一个大小为1G的swap分区,并创建好文件系统,并启用之;
# mkswap /dev/sdb2 正在设置交换空间版本 1,大小 = 1048572 KiB 无标签,UUID=a5c89d64-5fda-4ebd-9b00-92231cd57bae # swapon /dev/sdb2
3.写一个脚本:
(1)获取并列出当前系统上的所有磁盘设备;
(2)显示每个磁盘设备上每个分区相关的空间使用信息;
#!/bin/bash # fdisk -l | grep -o "/dev/sd[[:alnum:]]\{2\}" echo df -h
4.总结RAID的各个级别及其组合方式和性能的不同;
磁盘阵列(Redundant Arrays of Independent Disks,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+
5.创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128K;
# mdadm -C /dev/md1 -a yes -c 128 -x 1 -l 1 -n 2 /dev/sdb{1,2,3}
6.创建一个大小为4G的RAID5设备,chunk大小为256K,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能;
# mdadm -C /dev/md5 -n 3 -l 5 -a yes /dev/sdb{1,2,3} -c 256 # mkfs.ext4 /dev/md5 # echo "/dev/md5 /backup ext4 noatime,acl 0 0" &>> /etc/fstab
7.写一个脚本:
(1) 接受一个以上文件路径作为参数;
(2) 显示每个文件拥有的行数;
(3) 总结说明本次共为几个文件统计了其行数;
#!/bin/bash # if [ $# -eq 0 ];then echo "Please input in least two file." exit 2 fi for i in $*;do if [ -e $i ];then echo "$i total lines : $(cat $i | wc -l)" echo "File total:$#" else echo "No such file" fi done echo " the file number is:" $#
8.写一个脚本:
(1) 传递两个以上字符串当作用户名;
(2) 创建这些用户;且密码同用户名;
(3) 总结说明共创建了几个用户;
#!/bin/bash # if [ $# -lt 2 ];then echo "Please input two username!" exit 1 fi for i in [email protected]; do if cat /etc/passwd | grep $i &> /dev/null; then echo "user $i already exits" else useradd $i echo $i | passwd --stdin $i &> /dev/null echo "$i added to current system" let createdUser+=1 fi done echo "number of users created: $createdUser"
9.写一个脚本,新建20个用户,visitor1-visitor20;计算他们的ID之和;
#!/bin/bash # declare -i sum=0 U=visitor for i in {1..20};do useradd $U$i uid=`id -u $U$i` let sum+=$uid done echo "User ID sum:$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 # name=`cat /etc/passwd | grep "/bin/bash" | cut -d: -f1` echo -e "The default shell is bash user:\n$name" namesum=`cat /etc/passwd | grep "/bin/bash" | cut -d: -f1 | wc -l` echo "The default shell is bash user sum:$namesum" declare -i uidsum=0 uid=`cat /etc/passwd | grep "/bin/bash" | cut -d: -f3` for i in $uid;do let uidsum+=$i done echo -e "The default shell is bash UID:\n$uid" echo "The default shell is bash UID sum:$uidsum"
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 -l /dev/sdb # pvcreate /dev/sdb{1,2} # vgcreate -s 8 vg0 /dev/sdb1 /dev/sdb2 # lvcreate -L 5g -n mylv1 /dev/vg0 # mke2fs -t ext4 /dev/vg0//mylv1 # echo "/dev/vg0/mylv1 /users ext4 defaults,acl 0 0 " &>> /etc/fstab
14.新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录;
# useradd -d /users/magedu magedu # su magedu # cp -r /tmp/ /users/magedu
15.扩展mylv1至9G,确保扩展完成后原有数据完全可用;
# lvexpand -L 9G /dev/myvg/mylv1
16.缩减mylv1至7G,确保缩减完成后原有数据完全可用;
# umount /dev/vgtest/mylv1 # e2fsck -f /dev/myvg/mylv1 # resize2fs /dev/myvg/mylv1 7G # lvreduce -L 7G /dev/myvg/mylv1 # mount -a