1、创建一个10G分区,并格式为ext4文件系统;
[root@localhost xuc]# cat /proc/partitions
major minor #blocks name
8 0 104857600 sda
8 1 524288 sda1
8 2 20971520 sda2
8 3 10485760 sda3
8 4 10485235 sda4 //新建分区10G
(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;
[root@localhost xuc]# mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sda4
mke2fs 1.41.12 (17-May-2010)
文件系统标签=MYDATA
操作系统:linux
块大小=2048 (log=1)
分块大小=2048 (log=1)
Stride=0 blocks, Stripe width=0 blocks
655360 inodes, 5242616 blocks
104852 blocks (2.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=542113792
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
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 28 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
(2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;
[root@localhost xuc]# mkdir -pv /data/mydata
mkdir: 已创建目录 "/data"
mkdir: 已创建目录 "/data/mydata"
[root@localhost xuc]# mount -o noexec,noatime /dev/sda4 /data/mydata/
[root@localhost xuc]# mount
/dev/sda2 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw,rootcontext="system_u:object_r:tmpfs_t:s0")
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
/dev/sda4 on /data/mydata type ext4 (rw,noexec,noatime) 2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之; //由于内存4G,因此这次创建的swap是内存2倍10G,而不是题目要求的1G
Device Boot Start End Blocks Id System
/dev/sda1 * 1 66 524288 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 66 1371 10485760 83 Linux
Command (m for help): n
Command action
e extended
p primary partition (1-4)
p
Partition number (1-4): 3
First cylinder (1371-10443, default 1371):
Using default value 1371
Last cylinder, +cylinders or +size{K,M,G} (1371-10443, default 10443): +10G
Command (m for help): m
Command action
a toggle a bootable flag
b edit bsd disklabel
c toggle the dos compatibility flag
d delete a partition
l list known partition types
m print this menu
n add a new partition
o create a new empty DOS partition table
p print the partition table
q quit without saving changes
s create a new empty Sun disklabel
t change a partition's system id
u change display/entry units
v verify the partition table
w write table to disk and exit
x extra functionality (experts only)
Command (m for help): t
Partition number (1-4): 3
Hex code (type L to list codes): 82
Changed system type of partition 3 to 82 (Linux swap / Solaris)
Command (m for help): p
Disk /dev/sda: 85.9 GB, 85899345920 bytes
255 heads, 63 sectors/track, 10443 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x0006bb86
Device Boot Start End Blocks Id System
/dev/sda1 * 1 66 524288 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 66 1371 10485760 83 Linux
/dev/sda3 1371 2676 10483898 82 Linux swap / Solaris
Command (m for help): w
The partition table has been altered!
[root@localhost xuc]# partx -a /dev/sda
BLKPG: Device or resource busy
error adding partition 1
BLKPG: Device or resource busy
error adding partition 2
BLKPG: Device or resource busy
error adding partition 3
[root@localhost xuc]# cat /proc/partitions
major minor #blocks name
8 0 83886080 sda
8 1 524288 sda1
8 2 10485760 sda2
8 3 10483898 sda3
[root@localhost xuc]# mkswap /dev/sda3
Setting up swapspace version 1, size = 10483892 KiB
no label, UUID=a382c6e1-521f-4142-99f4-cb67146809fe
[root@localhost xuc]# swapon /dev/sda3 3、写一个脚本 (1)、获取并列出当前系统上的所有磁盘设备;
(2)、显示每个磁盘设备上每个分区相关的空间使用信息;
//通过函数调用来实现,第一个用cut,第二个用awk
#!/bin/bash
#
diskinfo(){
echo -e "Disks on the deivce:"
fdisk -l |egrep -o '^Disk /dev/sd[a-z]'|cut -d" " -f2
}
usage(){
df -h |egrep '/dev/sd' |awk -F' ' 'BEGIN{print "Usage is :"}{print $1,$3}'
}
diskinfo
echo
usage
[root@localhost test-scripts]# bash diskinfo
Disks on the deivce:
/dev/sda
Usage is :
/dev/sda2 2.8G
/dev/sda1 38M 4、总结RAID的各个级别及其组合方式和性能的不同;
![马哥教育N22期第七周作业]()
5、创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128k; //正好有两个扩展分区磁盘为10G的 就做了RAID
[root@localhost test-scripts]# mdadm -C /dev/md0 -n 2 -l 1 -c 128 /dev/sda{5,6}
[root@localhost test-scripts]# mdadm -D /dev/md0
/dev/md0:
Version : 1.2
Creation Time : Sat Oct 8 18:05:03 2016
Raid Level : raid1
Array Size : 10482176 (10.00 GiB 10.73 GB)
Used Dev Size : 10482176 (10.00 GiB 10.73 GB)
Raid Devices : 2
Total Devices : 2
Persistence : Superblock is persistent
Update Time : Sat Oct 8 18:05:26 2016
State : clean, resyncing
Active Devices : 2
Working Devices : 2
Failed Devices : 0
Spare Devices : 0
Resync Status : 44% complete
Name : localhost.localdomain:0 (local to host localhost.localdomain)
UUID : bee8c695:a50dfdfc:b3021feb:c3cafbba
Events : 7
Number Major Minor RaidDevice State
0 8 5 0 active sync /dev/sda5
1 8 6 1 active sync /dev/sda6 6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能; [root@localhost test-scripts]# mdadm -C /dev/md1 -n 3 -l 5 -c 256 /dev/sda{7,8,9}
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md1 started.
[root@localhost test-scripts]# mke2fs -t ext4 /dev/md1
mke2fs 1.41.12 (17-May-2010)
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=64 blocks, Stripe width=128 blocks
262944 inodes, 1051136 blocks
52556 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1077936128
33 block groups
32768 blocks per group, 32768 fragments per group
7968 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 22 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
[root@localhost ~]# vim /etc/fstab
tmpfs /dev/shm tmpfs defaults 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/md1 /backup ext4 noatime,acl 0 0 7、写一个脚本 (1) 接受一个以上文件路径作为参数;
(2) 显示每个文件拥有的行数;
(3) 总结说明本次共为几个文件统计了其行数;
#!/bin/bash
#
if [ $# -lt 1 ]; then
echo "no parament,retry plz"
exit 1
else
for i in $*;do
echo -n "$i file line is :"
cat $i |wc -l
done
fi
echo "Total file number is $#"
[root@localhost test-scripts]# bash fileline.sh /etc/passwd /etc/fstab
/etc/passwd file line is :32
/etc/fstab file line is :15
Total file number is 2
[root@localhost test-scripts]# bash fileline.sh
no parament,retry plz 8、写一个脚本 (1) 传递两个以上字符串当作用户名;
(2) 创建这些用户;且密码同用户名;
(3) 总结说明共创建了几个用户;
#!/bin/bash
#
declare -i count=0
if [ $# -le 1 ]; then
echo "no parament,retry plz"
exit 1
fi
for i in $*;do
id $i &>/dev/null
if [ $? -eq 0 ];then
echo "$i is already exist"
else
useradd $i
echo "$i" |passwd --stadin $i &>/dev/null
let count+=1
fi
done
echo "Total parament is $#,create username is $count"
[root@localhost test-scripts]# bash adduser.sh tom mike
tom is already exist
mike is already exist
Total parament is 2,create username is 0
[root@localhost test-scripts]# bash adduser.sh tom jerry
tom is already exist
Total parament is 2,create username is 1 9、写一个脚本,新建20个用户,visitor1-visitor20;计算他们的UID之和; #!/bin/bash
#
declare -i uid_sum=0
declare -i uid=0
for i in {1..20};do
useradd visitor$i
id visitor$i &>/dev/null
uid=`id visitor$i |cut -d" " -f1 |egrep -o '[0-9]{3}'`
let uid_sum+=uid
done
echo "visitor1~visitor20 UID_SUM is $uid_sum"
[root@localhost test-scripts]# bash UID_SUM.sh
uid=501(visitor1) gid=501(visitor1) 组=501(visitor1)
uid=502(visitor2) gid=502(visitor2) 组=502(visitor2)
uid=503(visitor3) gid=503(visitor3) 组=503(visitor3)
uid=504(visitor4) gid=504(visitor4) 组=504(visitor4)
uid=505(visitor5) gid=505(visitor5) 组=505(visitor5)
uid=506(visitor6) gid=506(visitor6) 组=506(visitor6)
uid=507(visitor7) gid=507(visitor7) 组=507(visitor7)
uid=508(visitor8) gid=508(visitor8) 组=508(visitor8)
uid=509(visitor9) gid=509(visitor9) 组=509(visitor9)
uid=510(visitor10) gid=510(visitor10) 组=510(visitor10)
uid=511(visitor11) gid=511(visitor11) 组=511(visitor11)
uid=512(visitor12) gid=512(visitor12) 组=512(visitor12)
uid=513(visitor13) gid=513(visitor13) 组=513(visitor13)
uid=514(visitor14) gid=514(visitor14) 组=514(visitor14)
uid=515(visitor15) gid=515(visitor15) 组=515(visitor15)
uid=516(visitor16) gid=516(visitor16) 组=516(visitor16)
uid=517(visitor17) gid=517(visitor17) 组=517(visitor17)
uid=518(visitor18) gid=518(visitor18) 组=518(visitor18)
uid=519(visitor19) gid=519(visitor19) 组=519(visitor19)
uid=520(visitor20) gid=520(visitor20) 组=520(visitor20)
visitor1~visitor20 UID_SUM is 10210 10、写一脚本,分别统计/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#号开头的行数之和,以及总的空白行数; #!/bin/bash
#
declare -i u1=0
declare -i u2=0
for i in $*;do
p=`grep '^#.*' $i |wc -l`
q=`grep '^[[:space:]]*$' $i |wc -l`
let u1+=p
let u2+=q
done
echo "# head line sum is $u1"
echo "space line sum is $u2"
[root@localhost test-scripts]# bash file_line.sh /etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab
# head line sum is 94
space line sum is 210 11、写一个脚本,显示当前系统上所有默认shell为bash的用户的用户名、UID以及此类所有用户的UID之和; #!/bin/bash
#
declare -i uid=0
awk -F: 'BEGIN{print "usershellname is bash"}$NF=="/bin/bash"{print $1,$NF}' /etc/passwd
p=`awk -F: '$NF=="/bin/bash"{print $3}' /etc/passwd`
for i in $p;do
let uid+=i
done
echo "uid_sum is :"
echo $uid
[root@localhost test-scripts]# bash showshell.sh
usershellname is bash
root /bin/bash
xuc /bin/bash
uid_sum is :
500 12、写一个脚本,显示当前系统上所有,拥有附加组的用户的用户名;并说明共有多少个此类用户; #!/bin/bash
#
echo "attach group users list :"
while read line;do
user_sum=$(echo $line |cut -d: -f1)
p=$(id -G $user_sum |wc -w)
if [ $p -ge 2 ];then
echo "$user_sum"
let sum+=1
fi
done < /etc/passwd
echo "The number of ownerattach user : $sum"
[root@localhost test-scripts]# bash ownerattach.sh
attach group users list :
bin
daemon
adm
postfix
xuc
The number of ownerattach user : 5 13、创建一个由至少两个物理卷组成的大小为20G的卷组;要求,PE大小为8M;而在卷组中创建一个大小为5G的逻辑卷mylv1,格式化为ext4文件系统,开机自动挂载至/users目录,支持acl; [root@localhost xuc]# pvcreate /dev/sda{10,11}
Physical volume "/dev/sda10" successfully created
Physical volume "/dev/sda11" successfully created
[root@localhost xuc]# pvs
PV VG Fmt Attr PSize PFree
/dev/sda10 lvm2 ---- 10.00g 10.00g
/dev/sda11 lvm2 ---- 10.00g 10.00g
[root@localhost xuc]# vgcreate -s 8M myvg /dev/sda{10,11}
Volume group "myvg" successfully created
[root@localhost xuc]# vgs
VG #PV #LV #SN Attr VSize VFree
myvg 2 0 0 wz--n- 20.00g 20.00g
[root@localhost xuc]# vgdisplay
--- Volume group ---
VG Name myvg
System ID
Format lvm2
Metadata Areas 2
Metadata Sequence No 1
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 0
Open LV 0
Max PV 0
Cur PV 2
Act PV 2
VG Size 20.00 GiB
PE Size 8.00 MiB
Total PE 2560
Alloc PE / Size 0 / 0
Free PE / Size 2560 / 20.00 GiB
VG UUID VkgZVT-aKpf-6sg2-kkIE-0Utc-npvJ-LJPvSO
[root@localhost xuc]# lvcreate -L 5G -n mylv1 myvg
Logical volume "mylv1" created.
[root@localhost xuc]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 5.00 GiB
Current LE 640
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256
Block device 253:0
[root@localhost xuc]# cd
[root@localhost ~]# mkdir users
[root@localhost ~]# vim /etc/fstab
tmpfs /dev/shm tmpfs defaults 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/md1 /backup ext4 noatime,acl 0 0
/dev/myvg/mglv1 /users ext4 acl 0 0
[root@localhost myvg]# mke2fs -t ext4 /dev/myvg/mylv1
mke2fs 1.41.12 (17-May-2010)
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
327680 inodes, 1310720 blocks
65536 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1342177280
40 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override. 14、新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录; [root@localhost myvg]# useradd -d /users/magedu magedu
[root@localhost myvg]# su magedu
[magedu@localhost myvg]$ cd /users/magedu/
[magedu@localhost ~]$ cp /etc/fstab /etc/passwd ./
[magedu@localhost ~]$ ls
fstab passwd 15、扩展mylv1至9G,确保扩展完成后原有数据完全可用; [root@localhost myvg]# lvextend -L +4G /dev/myvg/mylv1
Size of logical volume myvg/mylv1 changed from 5.00 GiB (640 extents) to 9.00 GiB (1152 extents).
Logical volume mylv1 successfully resized.
[root@test users]# resize2fs /dev/myvg/mylv1
[root@localhost myvg]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 9.00 GiB
Current LE 1152
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256
Block device 253:0 16、缩减mylv1至7G,确保缩减完成后原有数据完全可用; [root@localhost myvg]# lvreduce -L -2G /dev/myvg/mylv1
WARNING: Reducing active logical volume to 7.00 GiB.
THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce myvg/mylv1? [y/n]: y
Size of logical volume myvg/mylv1 changed from 9.00 GiB (1152 extents) to 7.00 GiB (896 extents).
Logical volume mylv1 successfully resized.
[root@test users]# resize2fs /dev/myvg/mylv1
[root@localhost myvg]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 7.00 GiB
Current LE 896
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256 17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息; [root@test users]# lvcreate -L 7G -p r -s -n mylv1_snapshot /dev/myvg/mylv1
major minor #blocks name
8 0 104857600 sda
8 1 524288 sda1
8 2 20971520 sda2
8 3 10485760 sda3
8 4 10485235 sda4 //新建分区10G
(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;
[root@localhost xuc]# mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sda4
mke2fs 1.41.12 (17-May-2010)
文件系统标签=MYDATA
操作系统:linux
块大小=2048 (log=1)
分块大小=2048 (log=1)
Stride=0 blocks, Stripe width=0 blocks
655360 inodes, 5242616 blocks
104852 blocks (2.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=542113792
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
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 28 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
(2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;
[root@localhost xuc]# mkdir -pv /data/mydata
mkdir: 已创建目录 "/data"
mkdir: 已创建目录 "/data/mydata"
[root@localhost xuc]# mount -o noexec,noatime /dev/sda4 /data/mydata/
[root@localhost xuc]# mount
/dev/sda2 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw,rootcontext="system_u:object_r:tmpfs_t:s0")
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
/dev/sda4 on /data/mydata type ext4 (rw,noexec,noatime) 2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之; //由于内存4G,因此这次创建的swap是内存2倍10G,而不是题目要求的1G
Device Boot Start End Blocks Id System
/dev/sda1 * 1 66 524288 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 66 1371 10485760 83 Linux
Command (m for help): n
Command action
e extended
p primary partition (1-4)
p
Partition number (1-4): 3
First cylinder (1371-10443, default 1371):
Using default value 1371
Last cylinder, +cylinders or +size{K,M,G} (1371-10443, default 10443): +10G
Command (m for help): m
Command action
a toggle a bootable flag
b edit bsd disklabel
c toggle the dos compatibility flag
d delete a partition
l list known partition types
m print this menu
n add a new partition
o create a new empty DOS partition table
p print the partition table
q quit without saving changes
s create a new empty Sun disklabel
t change a partition's system id
u change display/entry units
v verify the partition table
w write table to disk and exit
x extra functionality (experts only)
Command (m for help): t
Partition number (1-4): 3
Hex code (type L to list codes): 82
Changed system type of partition 3 to 82 (Linux swap / Solaris)
Command (m for help): p
Disk /dev/sda: 85.9 GB, 85899345920 bytes
255 heads, 63 sectors/track, 10443 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x0006bb86
Device Boot Start End Blocks Id System
/dev/sda1 * 1 66 524288 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 66 1371 10485760 83 Linux
/dev/sda3 1371 2676 10483898 82 Linux swap / Solaris
Command (m for help): w
The partition table has been altered!
[root@localhost xuc]# partx -a /dev/sda
BLKPG: Device or resource busy
error adding partition 1
BLKPG: Device or resource busy
error adding partition 2
BLKPG: Device or resource busy
error adding partition 3
[root@localhost xuc]# cat /proc/partitions
major minor #blocks name
8 0 83886080 sda
8 1 524288 sda1
8 2 10485760 sda2
8 3 10483898 sda3
[root@localhost xuc]# mkswap /dev/sda3
Setting up swapspace version 1, size = 10483892 KiB
no label, UUID=a382c6e1-521f-4142-99f4-cb67146809fe
[root@localhost xuc]# swapon /dev/sda3 3、写一个脚本 (1)、获取并列出当前系统上的所有磁盘设备;
(2)、显示每个磁盘设备上每个分区相关的空间使用信息;
//通过函数调用来实现,第一个用cut,第二个用awk
#!/bin/bash
#
diskinfo(){
echo -e "Disks on the deivce:"
fdisk -l |egrep -o '^Disk /dev/sd[a-z]'|cut -d" " -f2
}
usage(){
df -h |egrep '/dev/sd' |awk -F' ' 'BEGIN{print "Usage is :"}{print $1,$3}'
}
diskinfo
echo
usage
[root@localhost test-scripts]# bash diskinfo
Disks on the deivce:
/dev/sda
Usage is :
/dev/sda2 2.8G
/dev/sda1 38M 4、总结RAID的各个级别及其组合方式和性能的不同;
RAID:Redundant Arrays of Inexpensive Disks廉价磁盘冗余阵列 主要为了提高I/O能力和容错率
常用级别分为RAID-0,RADI-1,RAID-2…RAID-5,RAID-6,组合方式RAID10,RAID01
下面具体介绍一下具体实现和性能差异:

5、创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128k; //正好有两个扩展分区磁盘为10G的 就做了RAID
[root@localhost test-scripts]# mdadm -C /dev/md0 -n 2 -l 1 -c 128 /dev/sda{5,6}
[root@localhost test-scripts]# mdadm -D /dev/md0
/dev/md0:
Version : 1.2
Creation Time : Sat Oct 8 18:05:03 2016
Raid Level : raid1
Array Size : 10482176 (10.00 GiB 10.73 GB)
Used Dev Size : 10482176 (10.00 GiB 10.73 GB)
Raid Devices : 2
Total Devices : 2
Persistence : Superblock is persistent
Update Time : Sat Oct 8 18:05:26 2016
State : clean, resyncing
Active Devices : 2
Working Devices : 2
Failed Devices : 0
Spare Devices : 0
Resync Status : 44% complete
Name : localhost.localdomain:0 (local to host localhost.localdomain)
UUID : bee8c695:a50dfdfc:b3021feb:c3cafbba
Events : 7
Number Major Minor RaidDevice State
0 8 5 0 active sync /dev/sda5
1 8 6 1 active sync /dev/sda6 6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间戳,且支持acl功能; [root@localhost test-scripts]# mdadm -C /dev/md1 -n 3 -l 5 -c 256 /dev/sda{7,8,9}
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md1 started.
[root@localhost test-scripts]# mke2fs -t ext4 /dev/md1
mke2fs 1.41.12 (17-May-2010)
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=64 blocks, Stripe width=128 blocks
262944 inodes, 1051136 blocks
52556 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1077936128
33 block groups
32768 blocks per group, 32768 fragments per group
7968 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 22 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
[root@localhost ~]# vim /etc/fstab
tmpfs /dev/shm tmpfs defaults 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/md1 /backup ext4 noatime,acl 0 0 7、写一个脚本 (1) 接受一个以上文件路径作为参数;
(2) 显示每个文件拥有的行数;
(3) 总结说明本次共为几个文件统计了其行数;
#!/bin/bash
#
if [ $# -lt 1 ]; then
echo "no parament,retry plz"
exit 1
else
for i in $*;do
echo -n "$i file line is :"
cat $i |wc -l
done
fi
echo "Total file number is $#"
[root@localhost test-scripts]# bash fileline.sh /etc/passwd /etc/fstab
/etc/passwd file line is :32
/etc/fstab file line is :15
Total file number is 2
[root@localhost test-scripts]# bash fileline.sh
no parament,retry plz 8、写一个脚本 (1) 传递两个以上字符串当作用户名;
(2) 创建这些用户;且密码同用户名;
(3) 总结说明共创建了几个用户;
#!/bin/bash
#
declare -i count=0
if [ $# -le 1 ]; then
echo "no parament,retry plz"
exit 1
fi
for i in $*;do
id $i &>/dev/null
if [ $? -eq 0 ];then
echo "$i is already exist"
else
useradd $i
echo "$i" |passwd --stadin $i &>/dev/null
let count+=1
fi
done
echo "Total parament is $#,create username is $count"
[root@localhost test-scripts]# bash adduser.sh tom mike
tom is already exist
mike is already exist
Total parament is 2,create username is 0
[root@localhost test-scripts]# bash adduser.sh tom jerry
tom is already exist
Total parament is 2,create username is 1 9、写一个脚本,新建20个用户,visitor1-visitor20;计算他们的UID之和; #!/bin/bash
#
declare -i uid_sum=0
declare -i uid=0
for i in {1..20};do
useradd visitor$i
id visitor$i &>/dev/null
uid=`id visitor$i |cut -d" " -f1 |egrep -o '[0-9]{3}'`
let uid_sum+=uid
done
echo "visitor1~visitor20 UID_SUM is $uid_sum"
[root@localhost test-scripts]# bash UID_SUM.sh
uid=501(visitor1) gid=501(visitor1) 组=501(visitor1)
uid=502(visitor2) gid=502(visitor2) 组=502(visitor2)
uid=503(visitor3) gid=503(visitor3) 组=503(visitor3)
uid=504(visitor4) gid=504(visitor4) 组=504(visitor4)
uid=505(visitor5) gid=505(visitor5) 组=505(visitor5)
uid=506(visitor6) gid=506(visitor6) 组=506(visitor6)
uid=507(visitor7) gid=507(visitor7) 组=507(visitor7)
uid=508(visitor8) gid=508(visitor8) 组=508(visitor8)
uid=509(visitor9) gid=509(visitor9) 组=509(visitor9)
uid=510(visitor10) gid=510(visitor10) 组=510(visitor10)
uid=511(visitor11) gid=511(visitor11) 组=511(visitor11)
uid=512(visitor12) gid=512(visitor12) 组=512(visitor12)
uid=513(visitor13) gid=513(visitor13) 组=513(visitor13)
uid=514(visitor14) gid=514(visitor14) 组=514(visitor14)
uid=515(visitor15) gid=515(visitor15) 组=515(visitor15)
uid=516(visitor16) gid=516(visitor16) 组=516(visitor16)
uid=517(visitor17) gid=517(visitor17) 组=517(visitor17)
uid=518(visitor18) gid=518(visitor18) 组=518(visitor18)
uid=519(visitor19) gid=519(visitor19) 组=519(visitor19)
uid=520(visitor20) gid=520(visitor20) 组=520(visitor20)
visitor1~visitor20 UID_SUM is 10210 10、写一脚本,分别统计/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#号开头的行数之和,以及总的空白行数; #!/bin/bash
#
declare -i u1=0
declare -i u2=0
for i in $*;do
p=`grep '^#.*' $i |wc -l`
q=`grep '^[[:space:]]*$' $i |wc -l`
let u1+=p
let u2+=q
done
echo "# head line sum is $u1"
echo "space line sum is $u2"
[root@localhost test-scripts]# bash file_line.sh /etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab
# head line sum is 94
space line sum is 210 11、写一个脚本,显示当前系统上所有默认shell为bash的用户的用户名、UID以及此类所有用户的UID之和; #!/bin/bash
#
declare -i uid=0
awk -F: 'BEGIN{print "usershellname is bash"}$NF=="/bin/bash"{print $1,$NF}' /etc/passwd
p=`awk -F: '$NF=="/bin/bash"{print $3}' /etc/passwd`
for i in $p;do
let uid+=i
done
echo "uid_sum is :"
echo $uid
[root@localhost test-scripts]# bash showshell.sh
usershellname is bash
root /bin/bash
xuc /bin/bash
uid_sum is :
500 12、写一个脚本,显示当前系统上所有,拥有附加组的用户的用户名;并说明共有多少个此类用户; #!/bin/bash
#
echo "attach group users list :"
while read line;do
user_sum=$(echo $line |cut -d: -f1)
p=$(id -G $user_sum |wc -w)
if [ $p -ge 2 ];then
echo "$user_sum"
let sum+=1
fi
done < /etc/passwd
echo "The number of ownerattach user : $sum"
[root@localhost test-scripts]# bash ownerattach.sh
attach group users list :
bin
daemon
adm
postfix
xuc
The number of ownerattach user : 5 13、创建一个由至少两个物理卷组成的大小为20G的卷组;要求,PE大小为8M;而在卷组中创建一个大小为5G的逻辑卷mylv1,格式化为ext4文件系统,开机自动挂载至/users目录,支持acl; [root@localhost xuc]# pvcreate /dev/sda{10,11}
Physical volume "/dev/sda10" successfully created
Physical volume "/dev/sda11" successfully created
[root@localhost xuc]# pvs
PV VG Fmt Attr PSize PFree
/dev/sda10 lvm2 ---- 10.00g 10.00g
/dev/sda11 lvm2 ---- 10.00g 10.00g
[root@localhost xuc]# vgcreate -s 8M myvg /dev/sda{10,11}
Volume group "myvg" successfully created
[root@localhost xuc]# vgs
VG #PV #LV #SN Attr VSize VFree
myvg 2 0 0 wz--n- 20.00g 20.00g
[root@localhost xuc]# vgdisplay
--- Volume group ---
VG Name myvg
System ID
Format lvm2
Metadata Areas 2
Metadata Sequence No 1
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 0
Open LV 0
Max PV 0
Cur PV 2
Act PV 2
VG Size 20.00 GiB
PE Size 8.00 MiB
Total PE 2560
Alloc PE / Size 0 / 0
Free PE / Size 2560 / 20.00 GiB
VG UUID VkgZVT-aKpf-6sg2-kkIE-0Utc-npvJ-LJPvSO
[root@localhost xuc]# lvcreate -L 5G -n mylv1 myvg
Logical volume "mylv1" created.
[root@localhost xuc]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 5.00 GiB
Current LE 640
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256
Block device 253:0
[root@localhost xuc]# cd
[root@localhost ~]# mkdir users
[root@localhost ~]# vim /etc/fstab
tmpfs /dev/shm tmpfs defaults 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/md1 /backup ext4 noatime,acl 0 0
/dev/myvg/mglv1 /users ext4 acl 0 0
[root@localhost myvg]# mke2fs -t ext4 /dev/myvg/mylv1
mke2fs 1.41.12 (17-May-2010)
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
327680 inodes, 1310720 blocks
65536 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1342177280
40 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736
正在写入inode表: 完成
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override. 14、新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录; [root@localhost myvg]# useradd -d /users/magedu magedu
[root@localhost myvg]# su magedu
[magedu@localhost myvg]$ cd /users/magedu/
[magedu@localhost ~]$ cp /etc/fstab /etc/passwd ./
[magedu@localhost ~]$ ls
fstab passwd 15、扩展mylv1至9G,确保扩展完成后原有数据完全可用; [root@localhost myvg]# lvextend -L +4G /dev/myvg/mylv1
Size of logical volume myvg/mylv1 changed from 5.00 GiB (640 extents) to 9.00 GiB (1152 extents).
Logical volume mylv1 successfully resized.
[root@test users]# resize2fs /dev/myvg/mylv1
[root@localhost myvg]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 9.00 GiB
Current LE 1152
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256
Block device 253:0 16、缩减mylv1至7G,确保缩减完成后原有数据完全可用; [root@localhost myvg]# lvreduce -L -2G /dev/myvg/mylv1
WARNING: Reducing active logical volume to 7.00 GiB.
THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce myvg/mylv1? [y/n]: y
Size of logical volume myvg/mylv1 changed from 9.00 GiB (1152 extents) to 7.00 GiB (896 extents).
Logical volume mylv1 successfully resized.
[root@test users]# resize2fs /dev/myvg/mylv1
[root@localhost myvg]# lvdisplay
--- Logical volume ---
LV Path /dev/myvg/mylv1
LV Name mylv1
VG Name myvg
LV UUID 3pPfn1-tsw5-yPa0-yLg9-2xhB-iajm-HoH11e
LV Write Access read/write
LV Creation host, time localhost.localdomain, 2016-10-11 18:56:45 +0800
LV Status available
# open 0
LV Size 7.00 GiB
Current LE 896
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256 17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息; [root@test users]# lvcreate -L 7G -p r -s -n mylv1_snapshot /dev/myvg/mylv1