N22第七周作业

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 $@; 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

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

# lvcreate -s -L 7G -p r -n snapmylv1 /dev/myvg/mylv

原创文章,作者:N22-无锡-沉默,如若转载,请注明出处:http://www.178linux.com/52393

(0)
N22-无锡-沉默N22-无锡-沉默
上一篇 2016-10-24
下一篇 2016-10-24

相关推荐

  • linux命令简单应用

    创建/tmp目录下的:a_c, a_d, b_c, b_d touch /tmp/{a,b}_{c,d} [root@bogon ~]# tree /tmp /tmp |– a_c |– a_d |– b_c |– b_d 创建/tmp/mylinux目录下的: mylinux/ ├── bin ├── boo…

    Linux干货 2016-11-06
  • 马哥linux运维第一天感受

    101个人的大家庭

    Linux干货 2018-03-26
  • NFS(Network File System)介绍与应用(双httpd + php-fpm + nfs + mysql 搭建discuz论坛)

    NFS相关介绍 一、NFS简介     1. NFS(Network File System): NFS是一个文件共享协议, 也是是在类Unix系统中在内核中实现的文件系统。      2. 起源: 最早是由SUN公司研发,非常古老,只是实现文件共享,安全控制方面比较简…

    Linux干货 2015-07-21
  • 计算机的组成和Linux发展史

    计算机的组成及功能   计算机是由CPU,内存,输入装置和输出装置四大部件组成计算机,每一部件分别按要求执行特定的基本功能。  CPU: 控制器和运算器合称中央处理器,也就是CPU,它的功能主要是解释计算机指令以及处理计算机软件中的数据。  内存: 它是与CPU进行沟通的桥梁。计算机中所有程序的运行都是在内存中进行的,内存(Me…

    Linux干货 2016-10-30
  • 常用命令总结

    &:将要执行的进程送入后台进行执行alias:定义命令别名authconfig :对系统资源进行安全认证basename:抓取一个目录的基名basename pwdbzip2:压缩工具bzip2 case.sh case.sh.bz2    -[1-9]:指定压缩比   &nbsp…

    Linux干货 2017-04-09
  • nginx+tomcat+memcached构建session共享集群

    一、安装配置tomcat 配置前说明: 系统为centos7 m1.xsllqs.com地址为192.168.1.107 c1.xsllqs.com地址为192.168.1.114 c2.xsllqs.com地址为192.168.1.113 安装tomcat需要配合JDK使用,JDK有oracle JDK和open JDK两种 oracle JDK8的下载地…

    Linux干货 2016-06-26

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-02 14:46

    完成的非常好,给出了详细操作步骤,脚本思路清晰,加油!