磁盘分区和脚本练习

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

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

mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sdb5 
tune2fs -o acl /dev/sdb5 

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

mkdir /etc/mydate 
mount -o noexec,notime /dev/sdb5 /etc/mydate

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

[root@shijl ~]# mkswap /dev/sdb6
    Setting up swapspace version 1, size = 1053688 KiB
    no label, UUID=eab4467-707a-458c-b968-2f9d5ea28e2c
[root@shijl ~]#swapon /dev/sdb6

3、写一个脚本
  (1)获取并列出当前系统上的所有磁盘设备;
  (2)显示每个磁盘设备上每个分区相关的空间使用信息;

#!/bin/bash
#
fdisk_all=$(fdisk -l | grep "Disk")

echo "$fdisk_all"

fdisk_df=$(fdisk -l | grep "/dev/[sh]d[a-z][0-9]")
        
echo "$fdisk_df"

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

磁盘阵列比较表

RAID级别

最少硬盘

最大容错

可用容量

读取性能

写入性能

安全性

目的

应用产业

单一硬盘

(参考)

0

1

1

1

JBOD

1

0

n

1

1

无(同RAID 0

增加容量

个人(暂时)存储备份

0

2

0

n

n

n

一个硬盘异常,全部硬盘都会异常

追求最大容量、速度

视频剪接缓存用途

1

2

n-1

1

n

1

最高,一个正常即可

追求最大安全性

个人、企业备份

5

3

1

n-1

n-1

n-1

追求最大容量、最小预算

个人、企业备份

6

4

2

n-2

n-2

n-2

安全性较RAID 5

RAID 5,但较安全

个人、企业备份

10

4

n/2

n/2

n

n/2

安全性高

综合RAID 0/1优点,理论速度较快

大型数据库、服务器

5、创建一个大小为10G的RAID1,要求有一个空闲盘,而且CHUNK大小为128K

mdadm -C /dev/md0 -a yes -n 2 -x 1 -l 1 -c 128 /dev/sdb{5,6,7}

 6、创建一个大小为4G的RAID5设备,chunk大小为256k,格式化为ext4文件系统,要求可开机自动挂载至/backup目录,而且不更新访问时间,且支持acl功能

mdadm -C /dev/md0 -a yes -n 3 -c 256 /dev/sdb{5,6,7}
  mke2fs -t ext4 /dev/md0
  mkdir /backup 
  lkid /dev/md0
  /dev/md0: UUID="18646fc6-0175-4642-888d-8d4b5b7f59ce" TYPE="ext4" 
   vim /etc/fstab
    #
    # /etc/fstab
    # Created by anaconda on Wed Aug  9 04:49:47 2017
    #
    # 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
    #
    /dev/mapper/vg_shijl-lv_root /                       ext4    defaults        1 1
    UUID=fc11ec9c-2215-45b9-bc43-2d4c120733a5 /boot                   ext4    defaults        1 2
    /dev/mapper/vg_shijl-lv_home /home                   ext4    defaults        1 2
    /dev/mapper/vg_shijl-lv_swap swap                    swap    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
    UUID=18646fc6-0175-4642-888d-8d4b5b7f59ce /backup    ext4    defaults,acl,notime  0 0

7、写一个脚本
 (1)接受一个以上文件路径作为参数;
 (2)显示每个文件拥有的行数;
 (3)总结说明本次共为几个文件统计了其行数;

#!/bin/bash
#
declare -i count=0

if [ $# -lt 1 ];then
    echo " At least one filename."
    exit 2
fi


for i in $*;do
     if [ -e $i ];then
      wc -l $i
      count+=1
     else
          echo "$i isn't exist"
      fi
done

echo "$count files have been counted

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

#!/bin/bash
#
declare -i count=0
if [ $# -lt 2 ];then
  echo "At least two username"
  exit 2
fi

for i in $*;do
   if [ id $i &> /dev/null ];then
      echo "$i user is exist"
   else
      useradd $i
      echo "$i" | passwd --stdin $i &> /dev/null
      count+=1
    fi
done

echo " $count users have been create"

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

#!/bin/bash
#
declare -i count=0

for i in {1..20};do
   if [ id $i &> /dev/null ];then
      echo "user is  exits"
   else
       useradd vistorl$1 &> /dev/null
       uid $(id -u vistorl$1)
       count+=$uid
    fi
done
        
echo " ID sum is $count"

 

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

(0)
N27_shijinlongN27_shijinlong
上一篇 2017-08-21
下一篇 2017-08-21

相关推荐

  • gitlib环境部署

         GitLab是利用 Ruby on Rails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。它还提供一个代码片段收集功能可以轻松…

    2016-05-19
  • 8.6正则表达式grep及其他文本处理命令练习

    正则表达式grep及其他文本处理命令练习 上课练习 1 1、centos 6找出ifconfig命令结果中本机的IPv4地址 [root@qzx ~]# ifconfig|head -n 2|tail -n 1|tr -s ' [:alpha:]'&…

    Linux干货 2016-08-07
  • 用户和组命令的简单使用

    用户和组管理命令: 用户管理命令:useradd usermod userdel 组管理命令:groupadd groupmod groupdel 用户创建:useradd -u:uid 定义在/etc/login.defs -o:配合-u选项,不检查uid的唯一性 -g:gid,指明用户所属基本组,可为组名,也可以gid -c:用户的诠释信息 -d;指定用…

    Linux干货 2016-10-24
  • sed的用法小结

    sed的用法小结 sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等sed [OPTION]… ‘script’ [input-file] … OPTION: -n 不输出模式空间中的内容至屏幕,仅显示script处理后的结果 -e 多点编辑,eg: ~]# sed -e ‘s@^#[[…

    Linux干货 2017-08-22
  • 文件权限解析

    文件权限其实就是用户和用户组对文件或目录进行操作的权力。 文件的属性           上图中显示详细信息文件的详细属性,以最后一行为例从左向右依次说明:     1、drwxr-xr-x.    …

    2015-03-23
  • bash功能特性五 重定向和管道

    一、管道     使用“|”符号来实现管道功能;管道可以实现在一行中处理使用管道符号连接的多个命令,后面的命令使用前面命令的输出结果做为处理对象。 二、数据流重定向     数据输入和输出的类型:         标准输入(std…

    Linux干货 2015-04-21

评论列表(1条)

  • 马哥教育
    马哥教育 2017-09-02 20:54

    磁盘的操作直接关系到数据的安全,稍有不当,就可能导致数据的丢失,所以理解其概念非常有必要,执行命令前也要再三确认,加油。