马哥Linux第七周课程作业
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了马哥Linux第七周课程作业相关的知识,希望对你有一定的参考价值。
1、创建一个10G分区,并格式为ext4文件系统;
(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;
# 创建10G分区 [[email protected] ~]# fdisk /dev/sdb 命令(输入 m 获取帮助):n Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): p 分区号 (1-4,默认 1):1 起始 扇区 (2048-104857599,默认为 2048): 将使用默认值 2048 Last 扇区, +扇区 or +size{K,M,G} (2048-104857599,默认为 104857599):+10G 分区 1 已设置为 Linux 类型,大小设为 10 GiB 命令(输入 m 获取帮助):p 磁盘 /dev/sdb:53.7 GB, 53687091200 字节,104857600 个扇区 Units = 扇区 of 1 * 512 = 512 bytes 扇区大小(逻辑/物理):512 字节 / 512 字节 I/O 大小(最小/最佳):512 字节 / 512 字节 磁盘标签类型:dos 磁盘标识符:0xbde73b0a 设备 Boot Start End Blocks Id System /dev/sdb1 2048 20973567 10485760 83 Linux 命令(输入 m 获取帮助):w The partition table has been altered! Calling ioctl() to r
# 设置文件系统类型并指定参数设置 [[email protected] ~]# mke2fs -t 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: 完成 # 设置文件系统的默认挂载属性包含acl [[email protected] ~]# tune2fs -o acl /dev/sdb1 tune2fs 1.42.9 (28-Dec-2013)
(2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;
# 创建挂载文件夹 [[email protected] ~]# mkdir -pv /data/mydata mkdir: 已创建目录 "/data" mkdir: 已创建目录 "/data/mydata" [[email protected] ~]# mount -o noexec,noatime /dev/sdb1 /data/mydata [[email protected] ~]# mount /dev/sdb1 on /data/mydata type ext4 (rw,noexec,noatime,seclabel,data=ordered)
mount -o options:(挂载文件系统的选项) async:异步模式; sync:同步模式; atime/noatime:是否更新访问时间戳,包含目录和文件; diratime/nodiratime:是否更新目录的访问时间戳 auto/noauto:是否支持自动挂载 exec/noexec:是否支持应用程序自动运行 dev/nodev:是否支持在此文件系统上使用设备文件; remount:重新挂载 user/nouser:是否允许普通用户挂载此设备 acl:启用此文件系统上的acl功能 注意:上述选项可多个同时使用,彼此使用逗号分隔;
2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之;
[[email protected] ~]# fdisk /dev/sdb 命令(输入 m 获取帮助):n Partition type: p primary (1 primary, 0 extended, 3 free) e extended Select (default p): p 分区号 (2-4,默认 2):2 起始 扇区 (20973568-104857599,默认为 20973568): 将使用默认值 20973568 Last 扇区, +扇区 or +size{K,M,G} (20973568-104857599,默认为 104857599):+1G 分区 2 已设置为 Linux 类型,大小设为 1 GiB 命令(输入 m 获取帮助):t 分区号 (1,2,默认 2):2 Hex 代码(输入 L 列出所有代码):82 已将分区“Linux”的类型更改为“Linux swap / Solaris” 命令(输入 m 获取帮助):p 磁盘 /dev/sdb:53.7 GB, 53687091200 字节,104857600 个扇区 Units = 扇区 of 1 * 512 = 512 bytes 扇区大小(逻辑/物理):512 字节 / 512 字节 I/O 大小(最小/最佳):512 字节 / 512 字节 磁盘标签类型:dos 磁盘标识符:0xbde73b0a 设备 Boot Start End Blocks Id System /dev/sdb1 2048 20973567 10485760 83 Linux /dev/sdb2 20973568 23070719 1048576 82 Linux swap / Solaris 命令(输入 m 获取帮助):w [[email protected] ~]# partx -a /dev/sdb partx: /dev/sdb: error adding partition 1 [[email protected] ~]# mkswap /dev/sdb2 正在设置交换空间版本 1,大小 = 1048572 KiB 无标签,UUID=b30e0963-f82f-4a2f-8fb4-5f763d5f78bd [[email protected] ~]# free -m total used free shared buff/cache available Mem: 481 122 211 4 146 312 Swap: 1023 0 1023
3、写一个脚本
(1)、获取并列出当前系统上的所有磁盘设备;
(2)、显示每个磁盘设备上每个分区相关的空间使用信息;
[[email protected] tmp]# vim diskinfo.sh
#!/bin/bash # 获取并列出当前系统上的所有磁盘设备 echo "$(fdisk -l /dev/[sh]d[a-z] | grep -o ‘^Disk /dev/[sh]d[a-z]‘)" # 显示分区空间使用信息: diskDev=$(fdisk -l /dev/[sh]d[a-z] | grep -o ‘^/dev/[sh]d[a-z][[:digit:]]‘) for i in $diskDev do echo "$(df -lh $i)\n" done
[[email protected] tmp]# chmod +x diskinfo.sh [[email protected] tmp]# ./diskinfo.sh Disk /dev/sda Disk /dev/sdb Disk /dev/sdc Disk /dev/sdd Disk /dev/sde Filesystem Size Used Avail Use% Mounted on /dev/sda1 297M 158M 140M 54% /boot\n Filesystem Size Used Avail Use% Mounted on devtmpfs 479M 0 479M 0% /dev\n Filesystem Size Used Avail Use% Mounted on devtmpfs 479M 0 479M 0% /dev\n Filesystem Size Used Avail Use% Mounted on devtmpfs 479M 0 479M 0% /dev\n Filesystem Size Used Avail Use% Mounted on devtmpfs 479M 0 479M 0% /dev\n
4、总结RAID的各个级别及其组合方式和性能的不同;
RAID 0:将多个磁盘并列起来,成为一个大硬盘。存放数据时,其将数据分段同时写入,速度快。
优点:并行I/O,读写速度最快。
缺点:不具有冗余功能,有一个硬盘坏,则数据全部丢失。
最少磁盘数:2
RAID 1:两组相同的磁盘系统互作镜像,在主硬盘上存放数据的同时也在镜像硬盘上写相同的数据。
当主硬盘(物理)损坏时,镜像硬盘则代替主硬盘的工作,相当于备份。
优点:允许单个磁盘出错,可靠性最高,数据安全性在所有的RAID级别上来说是最好的。
缺点:速度没有提高,其磁盘的利用率却只有50%,是所有RAID上磁盘利用率最低的一个级别。
最少磁盘数:2
RAID 3:以一个硬盘来存放数据的奇偶校验位,数据则分段存储于其余硬盘中。
像RAID0一样以并行的方式来存放数据,但由于每次存放都需要进行校验,速度没有RAID0快。
校验盘固定为其中一块硬盘。
优点:允许单个磁盘出错,可靠性高,且磁盘利用率高(可用空间为n-1)
缺点:作为存放校验位的硬盘,工作负荷会很大,因为每次写操作,都会把生成的校验信息
写入该磁盘,而其它磁盘的负荷相对较小,这会对性能有一定的影响
最少磁盘数:3
RAID 5:在RAID 3的基础上,进行一些改进,奇偶校验数据均匀存放在阵列中的各个盘上,
优点:允许单个磁盘出错,可靠性高,相对Raid3来说,硬盘负荷相对较小。
缺点:每次存放数据会进行奇偶校验,增加工作负荷。损失一块硬盘空间。
最少磁盘数:3
RAID 6:类似于RAID 5,但其奇偶校验盘为2个,均匀存放在阵列中的各个盘上。
优点:允许2块磁盘出错,可靠性比RAID更高
缺点:存放数据时增加工作负荷,空间利用率低,为n-2
最少磁盘数:4
RAID-10:先将硬盘两两一组做成RAID-1,然后再将这一组组的RAID-1做成RAID-0。
优点:读、写性能提升,允许同一组内1个硬盘损坏
缺点:可用空间50%
最少磁盘数:4
RAID-01:先将硬盘分为2组,每一组硬盘单独做成RAID-0,然后将这两组硬盘做成RAID-1。
优点:读、写性能提升,有容错能力,可以损坏任意一组的硬盘(可以一组全坏)
缺点:可用空间50%
最少磁盘数:4
5、创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128k;
#对硬盘sde分配3个分区,大小均为10G,设置分区类型为fd(Linux raid auto) [[email protected] ~]# fdisk /dev/sde Command (m for help): n Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): p Partition number (1-4, default 1): First sector (2048-125829119, default 2048): Using default value 2048 Last sector, +sectors or +size{K,M,G} (2048-125829119, default 125829119): +10G Partition 1 of type Linux and of size 10 GiB is set Command (m for help): n Partition type: p primary (1 primary, 0 extended, 3 free) e extended Select (default p): p Partition number (2-4, default 2): First sector (20973568-125829119, default 20973568): Using default value 20973568 Last sector, +sectors or +size{K,M,G} (20973568-125829119, default 125829119): +10G Partition 2 of type Linux and of size 10 GiB is set Command (m for help): n Partition type: p primary (2 primary, 0 extended, 2 free) e extended Select (default p): p Partition number (3,4, default 3): 3 First sector (41945088-125829119, default 41945088): Using default value 41945088 Last sector, +sectors or +size{K,M,G} (41945088-125829119, default 125829119): +10G Partition 3 of type Linux and of size 10 GiB is set Command (m for help): t Partition number (1-3, default 3): 1 Hex code (type L to list all codes): fd Changed type of partition ‘Linux‘ to ‘Linux raid autodetect‘ Command (m for help): t Partition number (1-3, default 3): 2 Hex code (type L to list all codes): fd Changed type of partition ‘Linux‘ to ‘Linux raid autodetect‘ Command (m for help): t Partition number (1-3, default 3): 3 Hex code (type L to list all codes): fd Changed type of partition ‘Linux‘ to ‘Linux raid autodetect‘ Command (m for help): p Disk /dev/sde: 64.4 GB, 64424509440 bytes, 125829120 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x1646a2bb Device Boot Start End Blocks Id System /dev/sde1 2048 20973567 10485760 fd Linux raid autodetect /dev/sde2 20973568 41945087 10485760 fd Linux raid autodetect /dev/sde3 41945088 62916607 10485760 fd Linux raid autodetect [[email protected] ~]# partx -a /dev/sde partx: /dev/sde: error adding partitions 1-2
[[email protected] ~]# yum install mdadm #个别需要使用yum安装mdadm软件包
6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能;
7、写一个脚本
(1) 接受一个以上文件路径作为参数;
(2) 显示每个文件拥有的行数;
(3) 总结说明本次共为几个文件统计了其行数;
8、写一个脚本
(1) 传递两个以上字符串当作用户名;
(2) 创建这些用户;且密码同用户名;
(3) 总结说明共创建了几个用户;
9、写一个脚本,新建20个用户,visitor1-visitor20;计算他们的ID之和;
10、写一脚本,分别统计/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#号开头的行数之和,以及总的空白行数;
11、写一个脚本,显示当前系统上所有默认shell为bash的用户的用户名、UID以及此类所有用户的UID之和;
12、写一个脚本,显示当前系统上所有,拥有附加组的用户的用户名;并说明共有多少个此类用户;
13、创建一个由至少两个物理卷组成的大小为20G的卷组;要求,PE大小为8M;而在卷组中创建一个大小为5G的逻辑卷mylv1,格式化为ext4文件系统,开机自动挂载至/users目录,支持acl;
14、新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录;
15、扩展mylv1至9G,确保扩展完成后原有数据完全可用;
16、缩减mylv1至7G,确保缩减完成后原有数据完全可用;
17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息;
本文出自 “扬帆起航” 博客,请务必保留此出处http://mystery888.blog.51cto.com/9560453/1858992
以上是关于马哥Linux第七周课程作业的主要内容,如果未能解决你的问题,请参考以下文章
马哥2016全新Linux+Python高端运维班第七周作业
马哥2016全新Linux+Python高端运维班第七周作业