Linux下一代btrfs文件系统在centos中的应用

本文发布时间: 2019-Mar-22
btrfs作为Linux下一代文件系统与zfs有着许多相似的功能•扩展性 (scalability) 相关的特性,btrfs 最重要的设计目标是应对大型机器对文件系统的扩展性要求。 Extent,B-Tree 和动态 inode 创建等特性保证了 btrfs 在大型机器上仍有卓越的表现,其整体性能而不会随着系统容量的增加而降低。•其次是数据一致性 (data integrity) 相关的特性。系统面临不可预料的硬件故障,Btrfs 采用 COW 事务技术来保证文件系统的一致性。•btrfs 还支持 checksum,避免了 silent corrupt 的出现。而传统文件系统则无法做到这一点。•第三是和多设备管理相关的特性。 Btrfs 支持创建快照 (snapshot),和克隆 (clone) 。 btrfs 还能够方便的管理多个物理设备,使得传统的卷管理软件变得多余。•最后是其他难以归类的特性。这些特性都是比较先进的技术,能够显著提高文件系统的时间 / 空间性能,包括延迟分配,小文件的存储优化,目录索引等。它的特性我已经download一篇官方的文档,以供参照下面的操作是为了使centos能够方便使用btrfs我的操作系统是centos6.2内核版本是2.6.32yum install rpm-build fuse-devel libtool libtool-ltdl-devel boost-devel libedit-devel git e2fsprogs-develwget http://www.kernel.org/pub/linux/kernel/people/mason/btrfs/btrfs-progs-0.19.tar.gzwget http://downloads.sourceforge.net/e2fsprogs/e2fsprogs-1.41.14.tar.gztar xvzf e2fsprogs-1.41.14.tar.gz进入e2fsprogs-1.41.14目录后执行/configure --prefix=/usr/local/e2fsprogsmakemake install然后把uuid目录拷过去cp -r lib/uuid/ /usr/include/ \\这一步是为下面编译准备uuid/uuid.h库的ln -sv /lib/ln -s /lib/libuuid.so.1.3.0 /usr/lib/libuuid.so \\这步是为了防止编译时报错can not find -luuid 这个错误的tar xf btrfs-progs-0.19.tar.gzcd btrfs-progs-0.19在btrfsck.c中包含头文件stat.h 格式如下 \\这步是为了防止编译中报错#including <sys/stat.h>makemake install试使用btrfs文件系统关机添加一块新磁盘 系统默认识别为/dev/sdbCentos默认将btrfs编译成模块,如果想使用需要事先加载[root@localhost ~]# modprobe btrfs [root@localhost ~]# lsmod |grep btrfs btrfs 534417 0 zlib_deflate 19141 1 btrfs lzo_decompress 2155 1 btrfs lzo_compress 1979 1 btrfs libcrc32c 841 1 btrfs 分区 #fdisk /dev/sdb 建立一个分区1 使用默认的设置格式化#mkfs.btrfs /dev/sdb1[root@localhost ~]# btrfs-debug-tree /dev/sdb1 root tree leaf 29364224 items 9 free space 2349 generation 7 owner 1 fs uuid c6fab1d8-9a6c-47bb-86d9-55a7dac98bff chunk uuid a877c5ab-4296-4ff0-9f8e-9d6d26757a0a item 0 key (EXTENT_TREE ROOT_ITEM 0) itemoff 3756 itemsize 239 root data bytenr 29368320 level 0 dirid 0 refs 1 item 1 key (DEV_TREE ROOT_ITEM 0) itemoff 3517 itemsize 239 root data bytenr 29372416 level 0 dirid 0 refs 1 item 2 key (FS_TREE INODE_REF 6) itemoff 3500 itemsize 17 inode ref index 0 namelen 7 name: default item 3 key (FS_TREE ROOT_ITEM 0) itemoff 3261 itemsize 239 root data bytenr 29360128 level 0 dirid 256 refs 1 item 4 key (ROOT_TREE_DIR INODE_ITEM 0) itemoff 3101 itemsize 160 inode generation 4 size 0 block group 0 mode 40555 links 1 item 5 key (ROOT_TREE_DIR INODE_REF 6) itemoff 3089 itemsize 12 inode ref index 0 namelen 2 name: .. item 6 key (ROOT_TREE_DIR DIR_ITEM 2378154706) itemoff 3052 itemsize 37 location key (FS_TREE ROOT_ITEM 18446744073709551615) type 2 namelen 7 datalen 0 name: default item 7 key (CSUM_TREE ROOT_ITEM 0) itemoff 2813 itemsize 239 root data bytenr 29376512 level 0 dirid 0 refs 1 item 8 key (DATA_RELOC_TREE ROOT_ITEM 0) itemoff 2574 itemsize 239 root data bytenr 29380608 level 0 dirid 256 refs 1 chunk tree leaf 20971520 items 6 free space 3283 generation 5 owner 3 fs uuid c6fab1d8-9a6c-47bb-86d9-55a7dac98bff btrfs-debug-tree 这个命令能够显示各个 BTree 的变化情况,从而进一步理解每一个文件系统功能的内部实现细节创建 Snapshot下面的例子中,创建快照 snap1 时系统存在 2 个文件。创建快照之后,对 test1 的内容进行修改。再回到 snap1,打开 test1 文件,可以看到 test1 的内容依旧是之前的内容。#ls /Bfs test1 test2 #vi test1 this is a test #btrfsctl – s snap1 /Bfs #vi test1 Test1 is modified #cd /Bfs/snap1 #cat test1 this is a test 可以从上面的例子看到,快照 snap1 保存的内容不会被后续的写操作所改变。本文出自 “明日香” 博客


(以上内容不代表本站观点。)
---------------------------------
本网站以及域名有仲裁协议。
本網站以及域名有仲裁協議。

2024-Mar-04 02:11pm
栏目列表