LVM练习及quota和dd命令

练习

1、创建一个至少有两个PV组成的大小为20G的名为testvg的

VG;要求PE大小为16MB, 而后在卷组中创建大小为5G的逻

辑卷testlv;挂载至/users目录

第一步!首先准备足够大的硬盘来实验

[root@Cloud /]#lsblk  #添加了/dev/sdb/c硬盘 
NAME                MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sr0                  11:0    1  3.7G  0 rom  
sda                   8:0    0  200G  0 disk 
├─sda1                8:1    0  200M  0 part /boot
├─sda2                8:2    0   60G  0 part 
│ ├─vg0-root (dm-0) 253:0    0   20G  0 lvm  /
│ ├─vg0-swap (dm-1) 253:1    0    2G  0 lvm  [SWAP]
│ ├─vg0-usr (dm-6)  253:6    0   10G  0 lvm  /usr
│ └─vg0-var (dm-7)  253:7    0   20G  0 lvm  /var
└─sda3                8:3    0    1G  0 part 
sdc                   8:32   0   20G  0 disk 
sdb                   8:16   0   15G  0 disk

第二部!格式成LVM分区,具体操作就略过了,注意:在分区时记得把分区该为8e分区

[root@Cloud /]#fdisk -l |grep 'sd[bc]' #显示LVM分区
Disk /dev/sdc: 21.5 GB, 21474836480 bytes
/dev/sdc1               1        1306    10490413+  8e  Linux LVM
Disk /dev/sdb: 16.1 GB, 16106127360 bytes
/dev/sdb1               1        1306    10490413+  8e  Linux LVM

第三部!创建为pv卷

[root@Cloud /]#pvcreate /dev/sdb1 /dev/sdc1 #创建pv卷
  Physical volume "/dev/sdb1" successfully created
  Physical volume "/dev/sdc1" successfully created

第四部!创建vg组

[root@Cloud /]#vgcreate -s 16M testvg /dev/sdb1 /dev/sdc1 #创建卷名为testvg的vg卷,vg卷中包含/dev/sdb\c1
  Volume group "testvg" successfully created
[root@Cloud /]#vgdisplay testvg  #显示testvg
  --- Volume group ---
  VG Name               testvg
  System ID             
  Format                lvm2
  Metadata Areas        2
  Metadata Sequence No  1
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                0
  Open LV               0
  Max PV                0
  Cur PV                2
  Act PV                2
  VG Size               20.00 GiB #vg总大小
  PE Size               16.00 MiB #pe大小
  Total PE              1280
  Alloc PE / Size       0 / 0   
  Free  PE / Size       1280 / 20.00 GiB
  VG UUID               v4d6Uj-vPTv-FGTA-sVFx-sB15-FTGr-o7AQuJ

第四部!创建lv卷

   

[root@Cloud /]#lvcreate -L 5G -n testlv /dev/testvg #创建lv卷  vg组不支持补全。
  Logical volume "testlv" created.
[root@Cloud /]#lvdisplay /dev/testvg/testlv |grep 'LV Size' #查看lv大小 ,全路径查看
  LV Size                5.00 GiB

之后就是都比较简单就不截图了,直接命令表示

 mkdir /users #创建挂载点
    mke2fs -j /dev/testvg/testlv #格式化,系统随意
    mount /dev/testvg/testlv /users #挂载 就OK了!

注意:如果要删除以上操作顺序操作为

    取消挂载、删除lv卷、删除vg组、删除pv卷、删除分区!

[root@Cloud /]#umount /users #取消挂载
[root@Cloud /]#lvremove /dev/testvg/testlv  #删除lv卷
[root@Cloud /]#vgremove testvg #删除vg组
[root@Cloud /]#pvcreate /dev/sdb1 /dev/sdc1 #删除pv卷
  Physical volume "/dev/sdb1" successfully created
  Physical volume "/dev/sdc1" successfully created
[root@Cloud /]#dd if=/dev/zero of=/dev/sdb bs=512 count=1 #破坏分区!
1+0 records in
1+0 records out
512 bytes (512 B) copied, 0.0231221 s, 22.1 kB/s
[root@Cloud /]#dd if=/dev/zero of=/dev/sdc bs=512 count=1 #破坏分区!

有的时候分区格式化后lsblk还是查看不正常,可以使用partx -d /dev/DEVICE #cent6下使用

    


 2、新建用户archlinux,要求其家目录为/users/archlinux

,而后su切换至archlinux用户,复制/etc/pam.d目录至自己

的家目录

[root@Cloud /]#useradd -d /users/archlinux archlinux #新建用户archlinux
[archlinux@Cloud ~]# getent passwd archlinux #查看archlinux用户信息
archlinux:x:3002:3002::/users/archlinux:/bin/bash
[root@Cloud /users]#su - archlinux #切换用户
[archlinux@Cloud ~]$ cp -r  /etc/pam.d/ ./ #复制目录/etc/pam.d到当前目录
[archlinux@Cloud ~]$ ll pam.d/ -d #显示其信息
drwxr-xr-x 2 archlinux archlinux 4096 Sep  9 12:30 pam.d/


 3、扩展testlv至7G,要求archlinux用户的文件不能丢失

[root@Cloud /users]#lvextend -L 7G /dev/testvg/testlv #扩展至7G

  Size of logical volume testvg/testlv changed from 5.00 GiB (320 extents) to 7.00 GiB (448 extents

[root@Cloud /users]#lvs /dev/testvg/testlv #简要查看拓展的lv卷

  LV     VG     Attr       LSize Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert

  testlv testvg -wi-ao—- 7.00g  #显示为7G,成功

[root@Cloud /users/archlinux]#ll -d /users/archlinux/pam.d/ #数据大小未变

drwxr-xr-x 2 archlinux archlinux 4096 Sep  9 12:30 /users/archlinux/pam.d/

[root@Cloud /etc/pam.d]#ll /users/archlinux/pam.d/ |wc -l

56

   


 4、收缩testlv至3G,要求archlinux用户的文件不能丢失

[root@Cloud /users/archlinux]#lvreduce -L 3G /dev/testvg/testlv

  WARNING: Reducing active and open logical volume to 3.00 GiB.

  THIS MAY DESTROY YOUR DATA (filesystem etc.)

Do you really want to reduce testvg/testlv? [y/n]: y

  Size of logical volume testvg/testlv changed from 7.00 GiB (448 extents) to 3.00 GiB (192 extents).

  Logical volume testlv successfully resized.

[root@Cloud /users/archlinux]#lvs /dev/testvg/testlv

  LV     VG     Attr       LSize Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert

  testlv testvg -wi-ao—- 3.00g     

[root@Cloud /users/archlinux]#ll -d /users/archlinux/pam.d/ #数据大小未变

drwxr-xr-x 2 archlinux archlinux 4096 Sep  9 12:30 /users/archlinux/pam.d/

 

[root@Cloud /etc/pam.d]#ll /users/archlinux/pam.d/ |wc -l

56


 5、对testlv创建快照,并尝试基于快照备份数据,验正快照

的功能

[root@Cloud /users/archlinux]#lvcreate -s -L 512M -n mylv-snap -p r /dev/testvg/testlv #创建快照
  Logical volume "mylv-snap" created.
[root@Cloud /users/archlinux]#lvdisplay /dev/testvg/mylv-snap #显示快照详细信息
  --- Logical volume ---
  LV Path                /dev/testvg/mylv-snap
  LV Name                mylv-snap
  VG Name                testvg
  LV UUID                LVpNHy-ol30-OZCX-oo1J-d2cZ-2xhb-JrsAiw
  LV Write Access        read only
  LV Creation host, time Cloud.GO, 2016-09-09 14:28:50 +0800
  LV snapshot status     active destination for testlv
  LV Status              available
  # open                 0
  LV Size                3.00 GiB
  Current LE             192
  COW-table size         512.00 MiB
  COW-table LE           32
  Allocated to snapshot  0.00%
  Snapshot chunk size    4.00 KiB
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     256
  Block device           253:5
[root@Cloud /users/archlinux]#mount /dev/testvg/mylv-snap /mnt/snap/ #挂载快照
mount: block device /dev/mapper/testvg-mylv--snap is write-protected, mounting read-only
[root@Cloud /users/archlinux]#ll /mnt/snap/archlinux/pam.d/|wc -l #快照还有56个
56
[root@Cloud /users/archlinux]#rm /users/archlinux/pam.d/a #删除原有数据
abrt-cli-root   atd             authconfig      authconfig-gtk  authconfig-tui
[root@Cloud /users/archlinux]#rm /users/archlinux/pam.d/atd 
rm: remove regular file `/users/archlinux/pam.d/atd'? yes
[root@Cloud /users/archlinux]#rm /users/archlinux/pam.d/a*
rm: remove regular file `/users/archlinux/pam.d/abrt-cli-root'? yes
rm: remove regular file `/users/archlinux/pam.d/authconfig'? yes
rm: remove regular file `/users/archlinux/pam.d/authconfig-gtk'? yes
rm: remove regular file `/users/archlinux/pam.d/authconfig-tui'? yes
[root@Cloud /users/archlinux]#ll /users/archlinux/pam.d/| wc -l
51 #只剩下51个文件
[root@Cloud /]#cp -anr /mnt/snap/archlinux/pam.d/ /users/archlinux/ #恢复快照
[root@Cloud /]#ll /users/archlinux/pam.d/|wc -l #查看文件个数
56


磁盘配额

在内核中执行

•以文件系统为单位启用

•对不同组或者用户的策略不同

根据块或者节点进行限制

•执行软限制(soft limit)

•硬限制(hard limit)

初始化

•分区挂载选项:usrquota、grpquota

•初始化数据库:quotacheck

执行

•开启或者取消配额:quotaon、quotaoff

•直接编辑配额:edquota username

•在shell中直接编辑:

setquota usename 4096 5120 40 50 /foo

•定义原始标准用户

报告

• 用户调查:quota

• 配额概述:repquota

• 其它工具:warnquota

[root@Cloud /home]#lsblk |grep 'sdc' # #使用用的磁盘/dev/sdc1
sdc                   8:32   0   20G  0 disk 
└─sdc1                8:33   0   20G  0 part /home
[root@Cloud /]#mke2fs -t ext4 -L /home /dev/sdc1 #格式化
[root@Cloud /]#mkdir /mnt/home #创建空目录用来挂载
[root@Cloud /]#mount /dev/sdc1 /mnt/home/ #挂载
[root@Cloud /home]#mv * /mnt/home/#移动/home下的数据
root@Cloud /home]#cd /mnt/home/
[root@Cloud /mnt/home]#ls #显示挂载数据
lala  lost+found  mage  moon  user
[root@Cloud /mnt/home]#ll -h #详细信息
total 32K
drwx------ 4 lala root 4.0K Jul 28 17:47 lala
drwx------ 2 root root  16K Sep  8 19:26 lost+found
drwx------ 4 mage mage 4.0K Jul 27 19:11 mage
drwx------ 4 moon moon 4.0K Jul 28 17:52 moon
drwx------ 4 user user 4.0K Jul 28 17:44 user
[root@Cloud /]#vim /etc/fstab #挂载到/home
UUID="f5e56c7d-d3e4-4be1-b9f3-750b2f582e31"  /home ext4 defaults,usrquota,grpquota 0 0
[root@Cloud /]#mount -a #启用
[root@Cloud /home/lala]#mount |grep '/dev/sdc1' #查看挂载的信息
/dev/sdc1 on /home type ext4 (rw,usrquota,grpquota)
[root@Cloud /]#umount /mnt/home #卸载 
[root@Cloud /]#ll /home/ #查看挂载分区加入usrquota,grpquota
total 32
drwx------ 4 lala root  4096 Jul 28 17:47 lala
drwx------ 2 root root 16384 Sep  8 19:26 lost+found
drwx------ 4 mage mage  4096 Jul 27 19:11 mage
drwx------ 4 moon moon  4096 Jul 28 17:52 moon
drwx------ 4 user user  4096 Jul 28 17:44 user
[root@Cloud /home]#quotacheck -cug /home #创建quota数据库
[root@Cloud /home]#ls #信息。
aquota.group  aquota.user  lala  lost+found  mage  moon  user
[root@Cloud /home]#getenforce  #关于权限
Disabled #如果启用要改成禁用
[root@Cloud /home]#quotaon -p /home #查看quota是否看起!
group quota on /home (/dev/sdc1) is off
user quota on /home (/dev/sdc1) is off
[root@Cloud /home]#quotaon /home #开启home的quota
[root@Cloud /home]#quotaon -p /home/ #查看quota
group quota on /home (/dev/sdc1) is on
user quota on /home (/dev/sdc1) is on
[root@Cloud /home]#edquota lala #设置lala用户的磁盘配额
 #关于相信信息
Disk quotas for user lala (uid 3000):           #soft警告
  Filesystem                   blocks       soft       hard     inodes     soft     hard
  /dev/sdc1                        32          0          0          8        0        0
                     #已使用块数量(单位为k) (软数据大小)(硬数据大小)(inode数量)(软数量大小)(硬文件数量)
[root@Cloud /home/lala]#quota lala #更改的信息
Disk quotas for user lala (uid 3000): 
     Filesystem  blocks   quota   limit   grace   files   quota   limit   grace
      /dev/sdc1      32    1000    5000               8       0       0      
[root@Cloud /home/lala]#repquota /home #查看//home的所有quota
*** Report for user quotas on device /dev/sdc1
Block grace time: 7days; Inode grace time: 7days
                        Block limits                File limits
User            used    soft    hard  grace    used  soft  hard  grace
----------------------------------------------------------------------
root      --      20       0       0              3     0     0       
mage      --      36       0       0              9     0     0       
user      --      36       0       0              9     0     0       
lala      --      32    1000    5000              8     0     0       
moon      --      32       0       0              8     0     0       
  
[root@Cloud /home/lala]#edquota -p lala mage #lala和mage同一quota
[root@Cloud /home/lala]#repquota /home #查看/home所有quota
*** Report for user quotas on device /dev/sdc1
Block grace time: 7days; Inode grace time: 7days
                        Block limits                File limits
User            used    soft    hard  grace    used  soft  hard  grace
----------------------------------------------------------------------
root      --      20       0       0              3     0     0       
mage      --      36    1000    5000              9     0     0       
user      --      36       0       0              9     0     0       
lala      --      32    1000    5000              8     0     0       
moon      --      32       0       0              8     0     0 
[root@Cloud /home/lala]#setquota user 10000 20000 0 0 /home #一步到位设置quota
[root@Cloud /home/lala]#quota user #查看quota配置
Disk quotas for user user (uid 501): 
     Filesystem  blocks   quota   limit   grace   files   quota   limit   grace
      /dev/sdc1      36   10000   20000               9       0       0

     

   

dd命令

dd命令用于复制文件并对原文件的内容进行转换和格式化处理。

用法:

if=/PATH/FROM/SRC

    从 file 中读而不是标准输入。 

of=/PATH/TO/DEST

    写到 file 里去而不是标准输出。

bs=#:block size, 复制单元大小

count=#:复制多少个bs

of=file写到所命名的文件而不是到标准输出

if=file从所命名文件读取而不是从标准输入

bs=size指定块大小(既是是ibs也是obs)

ibs=size一次读size个byte

obs=size 一次写size个byte

cbs=size 一次转化size个byte

skip=blocks从开头忽略blocks个ibs大小的块

seek=blocks从开头忽略blocks个obs大小的块

count=n只拷贝n个记录

conv=conversion[,conversion…] 用指定的参数转换文件。

转换参数:

ascii 转换EBCDIC 为ASCII。

ebcdic 转换ASCII 为EBCDIC。

block 转换为长度为cbs 的记录,不足部分用空格填充。

unblock 替代cbs长度的每一行尾的空格为新行。

lcase 把大写字符转换为小写字符。

ucase 把小写字符转换为大写字符。

swab 交换输入的每对字节。

noerror 出错时不停止。

notrunc 不截短输出文件。

sync 把每个输入块填充到ibs个字节,不足部分用空(NUL)字符补齐

磁盘拷贝:

ddif=/dev/sdaof=/dev/sdb

备份MBR:

ddif=/dev/sdaof=/tmp/mbr.bakbs=512 count=1

破坏MBR中的bootloader:

ddif=/dev/zero of=/dev/sdabs=64 count=1 seek=446

有二进制文件fileA,size>2K。现在想从第64个字节位置开始读取,需要读取的大小是128Byts。又有fileB, 想把上面读取到的128Bytes写到第32个字节开始的位置,替换128Bytes,请问如何实现?

#ddif=fileAof=fileBbs=1 count=128 skip=63 seek=31 conv=notrunc

备份:

dd if=/dev/sdx of=/dev/sdy

将本地的/dev/sdx整盘备份到/dev/sdy

dd if=/dev/sdx of=/path/to/image

将/dev/sdx全盘数据备份到指定路径的image文件

dd if=/dev/sdx | gzip >/path/to/image.gz

备份/dev/sdx全盘数据,并利用gzip工具进行压缩,保存到指定路径

恢复:

dd if=/path/to/image of=/dev/sdx

将备份文件恢复到指定盘

gzip -dc /path/to/image.gz | dd of=/dev/sdx

将压缩的备份文件恢复到指定盘

拷贝内存资料到硬盘

dd if=/dev/mem of=/root/mem.bin bs=1024

将内存里的数据拷贝到root目录下的mem.bin文件

从光盘拷贝iso镜像

dd if=/dev/cdrom of=/root/cd.iso

拷贝光盘数据到root文件夹下,并保存为cd.iso文件

销毁磁盘数据

dd if=/dev/random of=/dev/sda1

利用随机的数据填充硬盘,在某些必要的场合可以用来销毁数据。执行此操作以后,/dev/sda1将无法挂载,创建和拷贝操作无法执行。

得到最恰当的block size

dd if=/dev/zero bs=1024 count=1000000 of=/root/1Gb.file

dd if=/dev/zero bs=2048 count=500000 of=/root/1Gb.file

dd if=/dev/zero bs=4096 count=250000 of=/root/1Gb.file

dd if=/dev/zero bs=8192 count=125000 of=/root/1Gb.file

通过比较dd指令输出中所显示的命令执行时间,即可确定系统最佳的block size大小

 

测试硬盘读写速度

dd if=/root/1Gb.file bs=64k | dd of=/dev/null

dd if=/dev/zero of=/root/1Gb.file bs=1024 count=1000000

通过上两个命令输出的执行时间,可以计算出测试硬盘的读/写速度

修复硬盘

dd if=/dev/sda of=/dev/sda

当硬盘较长时间(比如1,2年)放置不使用后,磁盘上会产生消磁点。当磁头读到这些区域时会遇到困难,并可能导致I/O错误。当这种情况影响到硬盘的第一个扇区时,可能导致硬盘报废。上边的命令有可能使这些数据起死回生。且这个过程是安全,高效的。

  

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

(1)
上一篇 2016-09-09 16:26
下一篇 2016-09-09 17:12

相关推荐

  • Ansible的基础知识

    为什么要学习ansible:     ansible是自动化运维的一种工具,使用ansible可以一次性管理多台主机,为多台主机安装或这执行相同或者不同的操作,省去了一台台主机去重复执行相同的任务,可以使用corn选项结合本机的crontab设置本主机的任务性计划,比如,每天导出nginx的access.log和err…

    Linux干货 2016-11-03
  • 文本处理工具

    文本处理工具 1、查看文件内容 cat -v 显示非打印字符       -E 显示$      -T 显示TAB      -n 显示行号      -s 将连续的重复空行变成一行      -A = -vE…

    2017-07-30
  • 浅谈群红包的实现

    前言:红包是支付的方式, 也是社交的延伸。群红包在这两块领域串联得很好, 表现尤为的浓墨重彩. 承接上两篇技术浅谈:1). 浅谈接龙红包的技术实现.2). 浅谈微信红包摇一摇的技术实现.这一次, 让我们谈谈群红包的技术实现. 一为是红包的分配算法, 二为竞抢的技术实现. 分配算法:最初玩群红包的时候, 并没有意识到分配算法的难度…

    Linux干货 2015-03-10
  • Kickstart+PXE自动部署CentOS6.6

        生产环境中对于部署大量的相同系统的服务器,如果逐台安装操作系统的话是非常浪费时间的工作,还好CentOS提供了无人值守安装系统的功能,下面就详细介绍一下配置步骤。 一、配置本机的yum源     因为需要安装一些软件来达到我们的目的,所以最好先把yum源配置好。 &nbs…

    Linux干货 2015-05-12
  • 进程理论和相关工具的使用

    内核的功用 进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等     Process: 运行中的程序的一个副本,是被载入内存的一个指令集合 进程ID(Process ID,PID)号码被用来标记各个进程     UID、GID、和SELinux语境决定对文件…

    Linux干货 2017-08-28
  • 也许你根本不会用百度搜索

    搜索引擎可以帮助使用者在Internet上找到特定的信息,但它们同时也会返回大量无关的信息。但是如果多使用一些技巧,你将发现搜索引擎会花尽可能少的时间找到你需要的确切信息。 1.简单查询 这个就是最简单便捷的使用方式,其实也是我们大多数人平时使用百度或者其他搜索引擎的方式。比如你想查培训学校,那么你的第一反应肯定就是在百度里输入【挖掘机】【挖掘机学校】【蓝翔…

    2015-03-02