btrfs 文件系统

简介

  Btrfs((B-tree,ButterFS ,Better FS通常念成Butter FS),由Oracle于2007年宣布并进行中的COW(copy-on-write式)文件系统。继ext3/4文件系统之后linux又有了比较强大的文件系统(btrfs文件系统),btrfs文件系统不仅可以将ext3/4系列的升级为btrfs文件系统也可以将其降级为ext3/4的文件系统,特别是单一文件大小的限制,总文件系统大小限制以及加入文件校验和特性。而且btrfs文件系统还具有快照,内建磁盘阵列(RAID)支持,支持子卷等功能,允许在线调整文件系统大小,更为“嚣张”的是btrfs文件系统还支持快照的快照。突破了之前的一些文件系统。 

一 btrfs核心特性

    1.多物理卷支持:btrfs可由多个底层物理卷组成;支持RAID,以联机“添加”、“移除”,“修改”;

    2.写时复制更新机制(CoW):复制、更新及替换指针,而非“就地”更新;

    3.数据及元数据校验码:checksum

    4.子卷:sub_volume,子卷实质上是一个保存文件和目录的命名的B树。它们的inode保存在树根之树中,可以为非根用户和组所有。子卷可选设定块配额。子卷内的所有块和      文件区段都有引用计数以便做快照。和虚拟机存储的动态扩展相似,其只按需使用设备空间,消除了许多半满的分区。用户也可用不同的挂载选项挂载子卷,得到更灵活的      安全性。

    5.快照:支持快照的快照;命令:btrfs subvolume snapshot

    6.透明压缩:分区里的每个文件都被自动压缩,不仅减小了文件的大小,还提高了性能。

    7.Btrfs支持在线碎片整理。命令: btrfs filesystem defragment


二 btrfs 常见命令以及一些命令的子命令

    

1.文件系统创建:

命令:mkfs.btrfs

   选项:-L 'LABEL'    #设置卷标

      -d< type>: raid0, raid1, raid5, raid6, raid10, single    #设置raid级别

      -m< profile>: raid0, raid1, raid5, raid6, raid10, single, dup

      -O< feature>

      -O list-all: 列出支持的所有feature;

     

2.文件系统命令管理,包括卷标管理,文件系统大小调整,及碎片管理

命令:btrfs filesystem< subcommand> <args>

btrfs filesystem 

          show :  属性查看

          df :   查看挂载点的可使用空间

          label : 设置器卷标

          resize: 动态调整btrfs大小

3.挂载文件系统:

命令:mount -t btrfs /dev/sdb MOUNT_POINT

 

4.透明压缩机制:

命令:mount -o compress={lzo|zlib} DEVICE MOUNT_POINT

 

5. 管理子卷和快照命令

命令:btrfs subvolume< subcommand> [<args>]

btrfs subvlome :

         Create:   创建子卷

         Delete:   删除子卷

         List:    列出子卷

         show:    显示子卷的详细信息

         syn:     同步内存上的数据到磁盘上

6.设备管理命令

命令:btrfs device< subcommand> <args>

btrfs device:

         add :     添加设备

         delete :  删除设备

         raid label:设置raid级别

 

7.块组均衡管理

命令:btrfs [filesystem] balance <subcommand>|<args>

btrfs balance :(原有的数据移动一部分到新增的物理卷上)

         start: 启用balance

         pause: 停止balance

         cancle:取消balance 

         status:查看balance状态

8.btrfs subvolume snapshot   创建快照卷

三 btrfs管理及应用

  1. 新增2块20磁盘 dev/sdb与/dev/sdc

    blob.png

  2. 创建btrfs文件系统和显示btrfs文件系统

  mkfs.btrfs -L 'mytest' /dev/sdb /dev/sdc

    blob.png

  blob.png

3.挂载文件系统

 mkdir /mytest/

 mount -t btrfs /dev/sdb /mytest/

 blob.png

3.建立子卷轴

btrfs subvolume create /mytest/mydata

cp -r /etc/grub2.cfg /mytest/mydata/

blob.png

btrfs subvolum show /mytest/mydata/

blob.png

4.删除子卷

blob.png

5.扩展文件系统

blob.png

6.重新均衡文件系统

blob.png

7.移除硬盘设备

btrfs device delete /dev/sdb /mytest/

blob.png

8.修改数据或元数据的RAID级别

btrfs filesystem df /mytest/

btrfs balance start -mconvert=raid5 /mytest/

blob.png

9.创建快照

btrfs subvolume snapshot /mytest/mydata/ /mytest/mydata_snapshot

blob.png

我们还能在一般的文件系统和btrfs文件系统之间转换:

btrfs-convert /dev/sdd1       COMMENTS: 一般文件系统转换成btrfs文件系统;

btrfs-convert -r /dev/sdd1     COMMENTS:btrfs文件系统转换回一般文件系统。

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

(0)
liangkailiangkai
上一篇 2016-02-19
下一篇 2016-02-22

相关推荐

  • 第八周作业

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;     在线的主机使用绿色显示;     不在线的主使用红色显示; #!/bin/bash for i in {1..254};do if ping -c 1 -w 1 192.16…

    2017-07-03
  • CentOS系统启动流程–上

    centos6启动流程 1.加载BIOS的硬件信息,获取第一个启动设备。 2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息 3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱 动所有的硬件设备。 4.核型执行init程序并获取运行信息。 5.Init执行/etc/rc.d/rc.sysinit文件。 6.启动核心的外挂模块(/etc/m…

    Linux干货 2016-09-13
  • Ansible初识

    Ansible概念 ansible是自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。说…

    2017-07-08
  • nginx负载均衡搭建

    组 网络拓扑图 nginx负载均衡服务器搭建 首先准备三台机器 主机A(nginx负载均衡器) 主机B 主机C 主机A需两块网卡(一块外网,一块内网) 主机B和主机C各一块 (各一块内网的IP,如果主机B C和主机A内网网卡在一个网段就不需要配置网关地址了。 规划好网络后,nginx负载主机分别ping下各rs主机是否可通 主机A打开核心转发功能 #echo…

    Linux干货 2017-05-17
  • Linux基础目录名称命名法则及功用规定

    FHS:文件系统层级结构标准 – Filesystem Hieracry Standard 参考这篇文档: http://refspecs.linuxfoundation.org/FHS_2.3/fhs-2.3.html  /bin:供所有用户使用的基本命令文件 /sbin:系统管理使用的工具程序 /boot:引导加载器必须用的静态文件…

    Linux干货 2016-08-15
  • Cent OS 6 编译方式安装LAMP

    细节要求: (1) 三者分离于三台主机; (2) 一个虚拟主机用于提供phpMyAdmin;另一个虚拟主机用于提供wordpress; (3) PHP使用FastCGI+xcache; (4) httpd使用非prefork的mpm模式; 一、CentOS6环境准备 1、OS(CentOS6.8)下开发环境包的安装,编译安装程序包需要使用 #yum grou…

    Linux干货 2017-02-24

评论列表(1条)