第七周練習

1、創建一個10G分區,并格式為ext4文件系統; 

 (1) 要求其block大小為2048, 預留空間百分比為2, 卷標為MYDATA, 默認掛載屬性包含acl;

  ~]# mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sda3

 (2) 掛載至/data/mydata目錄,要求掛載時禁止程序自動運行,且不更新文件的訪問時間戳;

  ~]# mount -o noexec,noatime,acl /dev/sda3 /mydata

2、創建一個大小為1G的swap分區,并創建好文件系統,并啟用之;

  ~]# mkswap device 開機自動啟用:寫在/etc/fstab文件中        DEVICE swap swap defaults 0 0

3、寫一個腳本  (1)、獲取并列出當前系統上的所有磁盤設備;  (2)、顯示每個磁盤設備上每個分區相關的空間使用信息;

#!/bin/bash
cat <查看所有磁盤設備
按D>查看磁盤分區使用信息
按Q>退出
EOF
read -p ‘請按對應的字母鍵,否則五秒后自動退出’ -t 5 name
if [[ "$name" == "Q" ]];then
    echo "您選擇退出";
    exit 1
elif [[ "$name" == "F" ]];then
    fdisk -l
elif [[ "$name" == "D" ]];then
    df -lh
else
    echo "您輸入有誤,請重啟后再試"
fi

4、總結RAID的各個級別及其組合方式和性能的不同;

見另一篇博客

5、創建一個大小為10G的RAID1,要求有一個空閑盤,而且CHUNK大小為128k;

# mdadm -C  /dev/md#  -n 2 -l 1 -x 1 -c 128 /dev/sda{1,2,3}

6、創建一個大小為4G的RAID5設備,chunk大小為256k,格式化ext4文件系統,要求可開機自動掛載至/backup目錄,而且不更新訪問時間戳,且支持acl功能;

#mdadm -C /dev/md# -a yes -n 3 -l 5  -c 256 /dev/sda{1,2,3}
#mkfs.ext4 /dev/md#
#mount  -o noatime,acl /dev/md# /backup

7、寫一個腳本

(1) 接受一個以上文件路徑作為參數;

(2) 顯示每個文件擁有的行數;

(3) 總結說明本次共為幾個文件統計了其行數;

#!/bin/bash
#
if [ $# -lt 1 ];then
    echo "At least one file path,try it again"
    exit 1
fi
for i in $*;do
    line=$(cat $i | wc -l)
    echo "$i文件的行數是$line"
done
echo "本次共統計$#個文件"

8、寫一個腳本

(1) 傳遞兩個以上字符串當作用戶名;

(2) 創建這些用戶;且密碼同用戶名;

(3) 總結說明共創建了幾個用戶;

#!/bin/bash
if [ $# -lt 2 ];then
    echo "At least two name,try it again please"
    exit 1
fi
for i in $*;do
    id $i &> /dev/null && exit 0 || useradd $i && echo $i | passwd --stdin $i
done
echo "共創建了$#個用戶"

9、寫一個腳本,新建20個用戶,visitor1-visitor20;計算他們的ID之和;

#!/bin/bash
#
sum=0
for i in {1..20};do
    id visitor$i &> /dev/null && echo "visitor$i已存在" && exit 0 || useradd visitor$i && echo "visitor$i創建成功"
done
for i in {1..20};do
    id=$(grep -E "visitor$i" /etc/passwd | cut -d: -f3)
    let sum+=$id
done
echo $sum

10、寫一腳本,分別統計/etc/rc.d/rc.sysinit、/etc/rc.d/init.d/functions和/etc/fstab文件中以#號開頭的行數之和,以及總的空白行數;

#!/bin/bash
#
num1=$(grep -E "#.*" $1 | wc -l)
num2=$(grep -E "#.*" $2 | wc -l)
num3=$(grep -E "#.*" $3 | wc -l)
empty1=$(grep -E "^[[:space:]]*$" $1  | wc -l)
empty2=$(grep -E "^[[:space:]]*$" $2  | wc -l)
empty3=$(grep -E "^[[:space:]]*$" $3  | wc -l)
let sum1=$num1+$num2+$num3
let sum2=$empty1+$empty2+$empty3
echo "#開頭的行數之和是$sum1,空白行數之和是$sum2"

11、寫一個腳本,顯示當前系統上所有默認shell為bash的用戶的用戶名、UID以及此類所有用戶的UID之和;

#!/bin/bash
#
awk -F: '$NF=="/bin/bash"{print $1,$3}' /etc/passwd
for i in $(grep -E ".*/bin/bash$" /etc/passwd | cut -d: -f3);do
    let sum+=$i
done
echo "UID之和是$sum"

12、寫一個腳本,顯示當前系統上所有,擁有附加組的用戶的用戶名;并說明共有多少個此類用戶;

#!/bin/bash
#
cat /etc/group | cut -d: -f1,4 | grep -E ".*:[^[:space:]]"
num=$(cat /etc/group | cut -d: -f1,4 | grep -E ".*:[^[:space:]]" | wc -l)
echo "共有此類用戶$num個"

13、創建一個由至少兩個物理卷組成的大小為20G的卷組;要求,PE大小為8M;而在卷組中創建一個大小為5G的邏輯卷mylv1,格式化為ext4文件系統,開機自動掛載至/users目錄,支持acl;

# vgcreate myvg -s 8M /dev/sdb1 /dev/sdc1
# lvcreate -L 5G -n mylv1 myvg
# mkfs.ext4 /dev/myvg/mylv1
# vim /etc/fstab
寫入
/dev/mapper/myvg-mylv1  /users  ext4    defaults,acl            0 0

14、新建用戶magedu;其家目錄為/users/magedu,而后su切換至此用戶,復制多個文件至家目錄;

mkdir -pv /user/magedu
useradd -d /users/magedu magedu

15、擴展mylv1至9G,確保擴展完成后原有數據完全可用;

# lvextend -L 9G /dev/myvg/mylv1

16、縮減mylv1至7G,確保縮減完成后原有數據完全可用;

# umount /dev/myvg/mylv1
# e2fsck -f /dev/myvg/mylv1
# resize2fs /dev/myvg/mylv1 7G
# lvreduce -L 7G /dev/myvg/mylv1
# mount /dev/myvg/mylv1 /users/

17、對mylv1創建快照,并通過備份數據;要求保留原有的屬主屬組等信息;

# lvcreate -s -L 512M -n mylv-snap -p r /dev/myvg/mylv1

原創文章,作者:N24_澀味,如若轉載,請注明出處:http://www.www58058.com/63151

(0)
N24_澀味N24_澀味
上一篇 2016-12-10
下一篇 2016-12-10

相關推薦

  • CA,DNS,LAMP實現wordpress

    拓撲圖見編譯實現LAMP,bind,CA.jpg test3配置:     yum -y install bind     修改named.conf配置文件:     //      listen-on por…

    2017-04-23
  • 利用keepalived搭建高可用集群

    在一個系統中,常常存在一些單點服務器,為了提高整個系統的穩定性,我們常常需要對這些單點服務做高可用配置;keepalived即為一種常用的高可用配置服務; Keepalived的工作模式有以下兩種: 1、 主/備:即單虛擬路徑器,僅配置一個VIP; 2、 主/主:即多個虛擬路徑器,配置多個VIP,每個虛擬路徑器作為其中某個VIP的的master虛擬路徑器; …

    Linux干貨 2016-11-01
  • RAID概述

    1、引言 RAID全稱Redundant Arrays of Inexpensive Disks / Redundant Arrays of Independent Disks,即獨立冗余磁盤陣列。RAID可以通過相關技術(軟件/硬件),將多個較小的磁盤整合成為一個較大的磁盤整體,而且能從某些方面提高數據的讀寫及數據保護。RAID分為不同…

    Linux干貨 2016-12-24
  • Linux高級文件系統管理之磁盤配額、RAID和LVM的使用

    磁盤配額Quota 磁盤配額(Quota)的作用:   在Linux系統中,由于是多用戶、多任務的環境,所以會有多用戶共同使用一個硬盤空間的情況發生,如果其中有少數幾個用戶大量占掉了硬盤空間的話,那肯定影響其他用戶的使用權限。因此管理員應該適當限制硬盤的空間給用戶,以妥善分配系統資源。 磁盤配額的一般用途    比較常使用的幾種…

    Linux干貨 2016-09-02
  • 震驚?。ptables還能這樣用!

    基本語法:iptables [-t 表] [操作命令] [鏈][規則匹配器][-j 目標動作] 系統的INPUT和OUTPUT默認策略為DROP; # iptables -P INPUT DROP # iptables -P OUTPUT DROP 1、限制本地主機的web服務器在周一不允許訪問;新請求的速率不能超過100個每秒;web服務器包含了admin…

    系統運維 2017-04-18
  • 基于Redis的開源分布式服務Codis

    Redis在豌豆莢的使用歷程——單實例==》多實例,業務代碼中做sharding==》單個Twemproxy==》多個Twemproxy==》Codis,豌豆莢自己開發的分布式Redis服務。在大規模的Redis使用過程中,他們發現Redis受限于多個方面:單機內存有限、帶寬壓力、單點問題、不能動態擴容以及磁盤損壞時的數據搶救。 Redis通常有3個使用途徑…

    Linux干貨 2015-02-25

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-12-14 13:51

    腳本的思路清晰,腳本需要考慮到無用的信息輸出問題。

欧美性久久久久