马哥教育网络班N22期+第7周课程练习

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

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

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

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

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

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

fdisk /dev/sdb
n
p2+1G
t82w
mkswap /dev/sdb2 
swapon /dev/sdb2

3、写一个脚本

(1)、获取并列出当前系统上的所有磁盘设备;

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

#!/bin/bashfor i in `blkid | cut -d: -f1`;do
    echo $i
    df -h $idone

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

屏幕快照 2016-10-17 13.01.15屏幕快照 2016-10-17 13.01.15.png
此图源自:维基百科

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

mdadm -C /dev/md0 -l1 -c128 -n2 -x1 /dev/sdb{1,2,3}

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

准备3块2G的磁盘分区,并格式化为ext4的格式:/dev/sdb{5,6,7}

mdadm -C /dev/md1 -n3 -l5 -c256 /dev/sdb{5,6,7}
mkfs.ext4 /dev/md1

vim /etc/fstab添加一行

/dev/md1 /backup ext4 defaults,acl,noatime 0 0

7、写一个脚本

(1) 接受一个以上文件路径作为参数;

(2) 显示每个文件拥有的行数;

(3) 总结说明本次共为几个文件统计了其行数;

#!/bin/bashdeclare -i sumdeclare -i fsum
sum=0fsum=0read -p "input filepath:" -a path
file_arg=${#path[*]}for i in `seq 0 $[${file_arg}-1] ` ;do
  echo "i=$i"
  if [ -e ${path[$i]} -a -f ${path[$i]} ] ;then
    fline=$(wc -l ${path[$i]}| cut -d' ' -f1)    echo "${path[$i]} lines is ${fline}"
    let sum=$sum+$fline
        let fsum+=1
  else
    echo "${path[$i]} is not file"
  fi
  echo "file number is $fsum ,sumlines $sum"done

8、写一个脚本

(1) 传递两个以上字符串当作用户名;

(2) 创建这些用户;且密码同用户名;

(3) 总结说明共创建了几个用户;

#!/bin/bashdeclare -i argnumread -p "input username:" -a u_name
argnum=${#u_name[*]}for i in `seq 0 $[$argnum-1]`;do
        useradd ${u_name[$i]}
        echo ${u_name[$i]} | passwd --stdin ${u_name[$i]} >/dev/nulldone
        echo "adduser count : $argnum "~

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

#!/bin/bashdeclare -i uiddeclare -i sum
sum=0for i in {1..20};do
  useradd visitor$i
  uid=$(id -u visitor$i)  let sum=$sum+$uiddone
  echo "uidsum is $sum"~

10、写一脚本,分别统计/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#号开头的行数之和,以及总的空白行数;

#!/bin/bash
 sum=$(sed -n '/^[#]/ p' /etc/rc.d/rc.sysinit | wc -l) echo $sum
 sum2=$(sed -n '/^[#]/ p' /etc/rc.d/init.d/functions | wc -l)  echo $sum2
 sum3=$(sed -n '/^[#]/ p' /etc/fstab | wc -l)  echo $sum3sumspace=$(sed -n '/^$/ p' /etc/rc.d/rc.sysinit /etc/fstab /etc/rc.d/init.d/functions| wc -l)  echo "space conut: $sumspace"

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

#!/bin/bashdeclare -i sum
sum=0sed -n '/bash$/p' /etc/passwd | cut -d: -f1,3for i in `sed -n '/bash$/p' /etc/passwd | cut -d: -f3`;do
        sum+=$idone
   echo "uidsum:$sum"

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

#!/bin/bashdeclare -i sum
sum=0while read lines;do
  username=$(echo $lines | cut -d: -f1)  if [ `id -G $username | wc -w` -ge 2 ];then
        sum+=1
        echo $username
   fidone</etc/passwdecho "user number : $sum"

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

创建4个大小为5G的分区:/dev/sd{b,c,d,e}1,使用fdisk的子命令-t变更分区id为8e。
1.创建PV

lvcreate /dev/sd{b,c,d,e}1



2.创建VG

vgcreate -s 8M myvg /dev/sd{b,c,d,e}1



3.创建带下为5G的逻辑卷mylv1

lvcreate -L 5G -n mylv1 myvg



4.格式化ext4文件系统

mkfs.ext4 /etc/mapper/myvg-mylv1



5.开机自动挂载
vim /etc/fstab

/etc/mapper/myvg-mylv1 /users ext4 defaults,acl 0 0


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

useradd -d /users/magedu magedusu -l magedu
cp /etc/fstab /etc/rc.d/rc.sysinit ~

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

resize2fs /etc/myvg/mylv1 9G

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

缩减文件系统容量

umount /users
resize2fs /dev/myvg/mylv1 7G



缩减lv容量

lvreduce -L 7G /dev/myvg/mylv1


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

lvcreate -s -n snapshot -L 512M /dev/myvg/mylv1

原创文章,作者:N22-武汉-enfp,如若转载,请注明出处:http://www.178linux.com/52377

(0)
N22-武汉-enfpN22-武汉-enfp
上一篇 2016-10-24
下一篇 2016-10-24

相关推荐

  • 使用ssh比较慢的小结

    1)情况说明 a、ping ip,响应正常 b、telnet ip,响应正常 c、ssh ip,响应慢,但是等很大会后还是能打开 2)处理方法 方法1: 修改本地中的/etc/ssh/ssh_config,把参数改为GSSAPIAuthentication no 方法2: a、修改远程服务器端的/etc/ssh/sshd_config ,把参数改为GSSAP…

    系统运维 2016-12-05
  • 博客作业网络班22期+第4周(8.29-9.4)

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 #  ls /home/tuser1 || mkdir /home/tuser1 && cp -R /etc/skel/*  /home/tuser1 && ch…

    Linux干货 2016-09-07
  • 深入浅出Docker(一):Docker核心技术预览

    原文链接:http://www.infoq.com/cn/articles/docker-core-technology-preview/ 【编者按】Docker是PaaS供应商dotCloud开源的一个基于LXC 的高级容器引擎,源代码托管在 GitHub 上,基于Go语言开发并遵从Apache2.0协议开源。Docker提供了一种在安全、可重复的环境中自…

    2015-04-10
  • shell脚本之 select 循环菜单及 函数

    select 循环与菜单 select variable in list    do      循环体命令   done select 循环主要用于创建菜单,按数字顺序排列的菜单项将显示在标准错误上,并显示PS3 提示符,等待用户输入 用户输入菜单列表中的某个数字,执行相应的命令…

    Linux干货 2016-08-22
  • httpd服务归纳:httpd基本配置(配置文件格式以及常用选项)

    一、 httpd文件的基本格式 主配置文件位置, /etc/httpd/conf/httpd.conf    1. 配置文件参数格式  配置参数    值       特点:    &nbs…

    Linux干货 2015-05-13
  • 推荐-使用iptables作为网络防火墙构建安全的网络环境

    使用iptables作为网络防火墙构建安全的网络环境 使用iptables作为网络防火墙构建安全的网络环境 前言 网络防火墙的优势 实验拓扑图 实验环境 实验步骤 防火墙未设置前对所有服务器的测试 针对不同服务器进行”非法”访问 定义网络防火墙规则 再次针对不同服务器进行”非法”访问 测试服务器是否可访问 总结 前言 一般情况下iptables只作为主机防火…

    Linux干货 2016-03-31