N22-℡浮生.若夢 ╮第七周作业

1、创建一个10G分区,并格式为ext4文件系统;


(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;

~]# mke2fs -t mkfs.ext4 -b 2048 -L MYDATA -m 2 /dev/sdb1
mke2fs 1.41.12 (17-May-2010)
文件系统标签=MYDATA
操作系统:Linux
块大小=2048 (log=1)
分块大小=2048 (log=1)
Stride=0 blocks, Stripe width=0 blocks
655360 inodes, 5241190 blocks
104823 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表: 完成                            
Writing superblocks and filesystem accounting information: 完成

This filesystem will be automatically checked every 27 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.

~]# tune2fs -o acl /dev/sdb1
tune2fs 1.41.12 (17-May-2010)

(2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;

~]# mkdir -pv /data/mydata
mkdir: 已创建目录 "/data"
mkdir: 已创建目录 "/data/mydata"

mount -o noatime,noexec /dev/sdb1 /data/mydata/

2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之;

# mkswap /dev/sdb2
# swapon /dev/sdb2

3、写一个脚本
(1)、获取并列出当前系统上的所有磁盘设备;

(2)、显示每个磁盘设备上每个分区相关的空间使用信息;

#!/bin/bash
fdisk -l |grep  "/dev/[hs]d*"
echo
df -h

4、总结RAID的各个级别及其组合方式和性能的不同;

RAID0:2快以上的磁盘并联起来,组成一个大容量硬盘。储放数据时,分段后分散储存在这些磁盘中。读写时可以并行处理,
      RAID0是速度最快的。
      无冗余功能,如果硬盘损坏,数据会丢失
      至少2快硬盘
      
RAID1:两组以上的N個磁盘相互作镜像,可用容量为总容量的一半。RAID 1的数据安全性在所有的RAID级别上来说是最好,
      读性能提升、写性能略有下降
      有容错能力:互为镜像
      至少2快硬盘
      
RAID5:RAID 5至少需要三块硬碟,RAID 5不是对存储的数据进行备份,而是把数据和相对应的奇偶校验信息存储到组成RAID5的各个磁盘上,并且奇偶校验信息和相对应的数据分别存储於不同的磁盘上。当RAID5的一个磁盘数据发生损坏後,可以利用剩下的数据和相应的奇偶校验信息去恢复被损坏的数据。
      读、写性能提升
      有容错能力:1块磁盘
      至少3快硬盘
      
RAID6:与RAID 5相比,RAID 6增加第二个独立的奇偶校验信息块。两个独立的奇偶系统使用不同的算法,数据的可靠性非常高,任意两块磁盘同时失效时不会影响数据完整性。
      读、写性能提升
      有容错能力:2块磁盘
      至少4快硬盘
      
RAID10:RAID10是一个混合型阵列,先是把2组(多组)做RAID1 再在2组(多组)基础上做RAID0,
      读、写性能提升
      有容错能力:每组镜像最多只能坏一块;
      至少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 [ $# -lt 1 ]; then
   echo "At least on path."
   exit 1
fi

for i in $@; do
    echo "$i have $(wc -l $i |cut -d" " -f1) lines."
done
    echo "The statistics of the number of lines for $# file"

8、写一个脚本
(1) 传递两个以上字符串当作用户名;
(2) 创建这些用户;且密码同用户名;
(3) 总结说明共创建了几个用户;

#!/bin/bash
#
if [ $# -lt 2 ]; then
    echo "Please enter a string of two or more"
    exit 2
fi

for i in $@; do
    useradd $i && echo $i | passwd --stdin $i &> /dev/null
done

echo "A total of created $# users"

9、写一个脚本,新建20个用户,visitor1-visitor20;计算他们的ID之和;

#!/bin/bash
###
declare -i sum=0
for i in {1..20};do
    useradd visitorl$i &> /dev/null
    uid=$(id -u visitorl$i)
    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 sum1=0;
declare -i sum2=0;
for i in /etc/rc.d/rc.sysinit /etc/rc.d/init.d/functions /etc/fstab; do
     sum1+=$( grep "^#" $i |wc -l)
     sum2+=$( grep "^[[:space:]]*$" $i |wc -l)
done

echo -e "# at the beginning of the row has: $sum1" " Empty line with: $sum2"

11、写一个脚本,显示当前系统上所有默认shell为bash的用户的用户名、UID以及此类所有用户的UID之和;

#!/bin/bash
####
declare -i sum=0;
grep "/bin/bash$" /etc/passwd | cut -d: -f1,3

for i in `grep "/bin/bash$" /etc/passwd | cut -d: -f3`;do
      sum=$[$sum+$i]
done        
            
echo "These users for the sum of the UID:$sum"

12、写一个脚本,显示当前系统上所有,拥有附加组的用户的用户名;并说明共有多少个此类用户;

#!/bin/bash
##
declare -i num=0;
for i in `cut -d: -f1 /etc/passwd`;do
      group=$(id $i | cut -d" " -f3 | awk -F, '{print $2}')
      if [ -n "$group" ];then
      echo $i
      let num++
      fi
done
echo "user number: $num"

13、创建一个由至少两个物理卷组成的大小为20G的卷而在卷组组;要求,PE大小为8M;中创建一个大小为5G的逻辑卷mylv1,格式化为ext4文件系统,开机自动挂载至/users目录,支持acl;

# pvcreate /dev/sda5
# pvcreate /dev/sda6

# pvdisplay 
  --- Physical volume ---
  PV Name               /dev/sda5
  VG Name               testvg
  PV Size               10.00 GiB / not usable 3.08 MiB
  Allocatable           yes 
  PE Size               8.00 MiB
  Total PE              1280
  Free PE               640
  Allocated PE          640
  PV UUID               Pc7Y2c-T4G4-VTEX-s9VB-5UJn-PA52-C00blh
   
  --- Physical volume ---
  PV Name               /dev/sda6
  VG Name               testvg
  PV Size               10.00 GiB / not usable 4.54 MiB
  Allocatable           yes 
  PE Size               8.00 MiB
  Total PE              1280
  Free PE               1280
  Allocated PE          0
  PV UUID               ogazfK-fOVm-jPF8-J5Xz-EWTf-N21W-nZrE12

# vgcreate -s 8M testvg /dev/sda5 /dev/sda6
# vgdisplay 
  --- Volume group ---
  VG Name               testvg
  System ID             
  Format                lvm2
  Metadata Areas        2
  Metadata Sequence No  2
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                1
  Open LV               1
  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       640 / 5.00 GiB
  Free  PE / Size       1920 / 15.00 GiB
  VG UUID               rUcw27-9g09-u15D-XxoY-xHAA-HPIt-q231rc
  
# lvcreate -L 5G -n mylv1 testvg
  ]# lvdisplay 
  --- Logical volume ---
  LV Path                /dev/testvg/mylv1
  LV Name                mylv1
  VG Name                testvg
  LV UUID                AB7oXl-Dcfd-igBB-BQku-2ndv-NRpP-XIBdI3
  LV Write Access        read/write
  LV Creation host, time mylinux, 2016-11-01 11:46:26 +0800
  LV Status              available
  # open                 1
  LV Size                5.00 GiB
  Current LE             640
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     256
  Block device           253:0
  
# mkfs.ext4 /dev/testvg/mylv1
# mkdir /tmp/users
# echo "/dev/testvg/mylv1       /tmp/users              ext4    defaults,acl    0 0" >> /etc/fastab

14、新建用户magedu;其家目录为/users/magedu,而后su切换至此用户,复制多个文件至家目录;

# mkdir -p /users/magedu
# useradd -d /users/magedu magedu
# su - magedu
# cp /etc/fstab /users/magedu

15、扩展mylv1至9G,确保扩展完成后原有数据完全可用;

# cp /etc/fstab /tmp/users
# lvextend -L +4GB /dev/testvg/mylv1

# resize2fs /dev/testvg/mylv1 
resize2fs 1.41.12 (17-May-2010)
Filesystem at /dev/testvg/mylv1 is mounted on /tmp/users; on-line resizing required
old desc_blocks = 1, new_desc_blocks = 1
Performing an on-line resize of /dev/testvg/mylv1 to 2359296 (4k) blocks.
The filesystem on /dev/testvg/mylv1 is now 2359296 blocks long.

# df -h
Filesystem                Size  Used Avail Use% Mounted on
/dev/sda2                  49G  2.6G   44G   6% /
tmpfs                     491M     0  491M   0% /dev/shm
/dev/sda1                 243M   30M  201M  13% /boot
/dev/mapper/testvg-mylv1  8.9G  140M  8.3G   2% /tmp/users

确保文件没有损坏
# cat fstab 

#
# /etc/fstab
# Created by anaconda on Thu Sep  8 18:07:56 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=9a4ecef6-d82c-471d-bed5-4187746129c4 /                       ext4    defaults        1 1
UUID=34e5f6cf-c318-4048-ae39-cd3b2490de6d /boot                   ext4    defaults        1 2
UUID=6b42d8fc-e214-48c6-9faf-c0bf08955c96 swap                    swap    defaults        0 0
UUID=d49020d0-abe0-4ff3-b289-8c10b90e8362 /media                  ext4    defaults        0 0 
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/testvg/mylv1	/tmp/users		ext4	defaults,acl	0 0

16、缩减mylv1至7G,确保缩减完成后原有数据完全可用;

# umount /dev/testvg/mylv1 

# e2fsck -f /dev/testvg/mylv1 
e2fsck 1.41.12 (17-May-2010)
第一步: 检查inode,块,和大小
第二步: 检查目录结构
第3步: 检查目录连接性
Pass 4: Checking reference counts
第5步: 检查簇概要信息
/dev/testvg/mylv1: 12/589824 files (0.0% non-contiguous), 72672/2359296 blocks

# resize2fs /dev/testvg/mylv1 7G
resize2fs 1.41.12 (17-May-2010)
Resizing the filesystem on /dev/testvg/mylv1 to 1835008 (4k) blocks.
The filesystem on /dev/testvg/mylv1 is now 1835008 blocks long

# lvresize -L 7GB /dev/testvg/mylv1 
  WARNING: Reducing active logical volume to 7.00 GiB
  THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce mylv1? [y/n]: y
  Reducing logical volume mylv1 to 7.00 GiB
  Logical volume mylv1 successfully resized
  
# mount /dev/testvg/mylv1 /tmp/users/
# df -h
Filesystem                Size  Used Avail Use% Mounted on
/dev/sda2                  49G  2.6G   44G   6% /
tmpfs                     491M     0  491M   0% /dev/shm
/dev/sda1                 243M   30M  201M  13% /boot
/dev/mapper/testvg-mylv1  6.9G  140M  6.5G   3% /tmp/users

确保文件没有损坏
# cat fstab   

#
# /etc/fstab
# Created by anaconda on Thu Sep  8 18:07:56 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=9a4ecef6-d82c-471d-bed5-4187746129c4 /                       ext4    defaults        1 1
UUID=34e5f6cf-c318-4048-ae39-cd3b2490de6d /boot                   ext4    defaults        1 2
UUID=6b42d8fc-e214-48c6-9faf-c0bf08955c96 swap                    swap    defaults        0 0
UUID=d49020d0-abe0-4ff3-b289-8c10b90e8362 /media                  ext4    defaults        0 0 
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/testvg/mylv1	/tmp/users		ext4	defaults,acl	0 0


17、对mylv1创建快照,并通过备份数据;要求保留原有的属主属组等信息;

# lvcreate -L 7G -p r -s -n snap_mylv1 /dev/testvg/mylv1

原创文章,作者:chenzhijie,如若转载,请注明出处:http://www.178linux.com/55877

(0)
chenzhijiechenzhijie
上一篇 2016-11-14
下一篇 2016-11-14

相关推荐

  • httpd功能配置之路径别名

       httpd的路径别名功能可以使用资源的访问不再依赖于站点的根目录,可以指定任意目录来设置资源的访问路径。    默认站点的根目录是/var/www/html,如下图所示。    下面来使用路径的别名来访问资源:    1、打开httpd服务的配置文件  &nbsp…

    Linux干货 2016-03-11
  • linux 系统启动流程探讨

    linux系统启动流程: linux系统启动流程,按层次分的话,可以分为内核空间的启动与用户空间的启动。 下面先说说内核空间的启动流程。 一个linux要跑起来,在最简陋的情况下,必须有:kernel , lib ,application kernel功能:加载驱动程序,内存管理,进程管理,文件系统,网络管理,安全管理,glibc 库: 是一个函数的集合,每…

    Linux干货 2017-04-11
  • 修改Linux命令终端提示符

    作业1. 设置自己的终端提示符,要求字符终端登录时:     a> 需要带颜色     b> 需要显示当前执行到了第几条命令     c> 显示当前登录终端,主机名和当前时间     这可以通…

    Linux干货 2016-10-17
  • Linux中的man命令使用方法

      Linux中的man命令就是manual的缩写,此命令是用来查看系统中自带的各种参考手册,帮助用户更好的了解并使用命令。   man命令的使用格式为: man COMMAND,即man后面跟上需要查询的命令,进到手册后有如下快捷按钮帮助用户更好的操作手册。     1.按键-j &nb…

    Linux干货 2016-10-20
  • N26-第五周博客

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; [root@localhost ~]# grep "^[[:space:]].*$" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行; [root…

    系统运维 2017-02-10
  • Linux用户和组的基础概念

    用户,组和权限管理   Multi-tasks,  Multi-Users 每个使用者:    用户标识,密码:    认证:Authentication    授权:Authorization    审计:Audition    3A 组…

    Linux干货 2016-12-21