来源:马哥教育linux
连接:https://mp.weixin.qq.com/s/UupllldADYE0sHbRs0uouQ算法
XfS文件系统是SGI开发的高级日志文件系统,XFS极具伸缩性,很是健壮。所幸的是SGI将其移植到了Linux系统中。在linux环境下。目前版本可用的最新XFS文件系统的为1.2版本,能够很好地工做在2.4核心下。安全
XFS文件系统简介工具
主要特性包括如下几点:性能
数据彻底性测试
采用XFS文件系统,当意想不到的宕机发生后,首先,因为文件系统开启了日志功能,因此你磁盘上的文件再也不会意外宕机而遭到破坏了。不论目前文件系统上存储的文件与数据有多少,文件系统均可以根据所记录的日志在很短的时间内迅速恢复磁盘文件内容。优化
传输特性日志
XFS文件系统采用优化算法,日志记录对总体文件操做影响很是小。XFS查询与分配存储空间很是快。xfs文件系统能连续提供快速的反应时间。笔者曾经对XFS、JFS、Ext三、ReiserFS文件系统进行过测试,XFS文件文件系统的性能表现至关出众。内存
可扩展性开发
XFS 是一个全64-bit的文件系统,它能够支持上百万T字节的存储空间。对特大文件及小尺寸文件的支持都表现出众,支持特大数量的目录。最大可支持的文件大小为263 = 9 x 1018 = 9 exabytes,最大文件系统尺寸为18 exabytes。
XFS使用高的表结构(B+树),保证了文件系统能够快速搜索与快速空间分配。XFS可以持续提供高速操做,文件系统的性能不受目录中目录及文件数量的限制。
传输带宽
XFS 能以接近裸设备I/O的性能存储数据。在单个文件系统的测试中,其吞吐量最高可达7GB每秒,对单个文件的读写操做,其吞吐量可达4GB每秒。
XFS文件系统的使用
下载与编译内核
下载相应版本的内核补丁,解压补丁软件包,对系统核心打补丁
下载地址:ftp://oss.sgi.com/projects/xfs/d … .4.18-all.patch.bz2
对核心打补丁,下载解压后,获得一个文件:xfs-1.1-2.4.18-all.patch文件。
对核心进行修补以下:
# cd /usr/src/linux
# patch -p1 < /path/to/xfs-1.1-2.4.18-all.patch
修补工做完成后,下一步要进行的工做是编译核心,将XFS编译进Linux核心可中。
首先运行如下命令,选择核心支持XFS文件系统:
#make menuconfig
在“文件系统“菜单中选择:
<*> SGI XFS filesystem support ##说明:将XFS文件系统的支持编译进核心或 SGI XFS filesystem support ##说明:以动态加载模块的方式支持XFS文件系统
另外还有两个选择:
Enable XFS DMAPI ##说明:对磁盘管理的API,存储管理应用程序使用
Enable XFS Quota ##说明:支持配合Quota对用户使用磁盘空间大小管理
完成以上工做后,退出并保存核心选择配置
以后,而后编译内核,安装核心:
#make bzImage
#make module
#make module_install
#make install
若是你对以上复杂繁琐的工做没有耐心或没有把握,那么能够直接从SGI的站点上下载已经打好补丁的核心,其版本为2.4.18。它是一个rpm软件包,你只要简单地安装便可。SGI提交的核心有两种,分别供smp及单处理器的机器使用。
建立XFS文件系统
完成对核心的编译后,还应下载与之配套的XFSprogs工具软件包,也即mkfs.xfs工具。否则咱们没法完成对分区的格式化:即没法将一个分区格式化成XFS文件系统的格式。要下载的软件包名称:xfsprogs-2.0.3。
将所下载的XFSProgs工具解压,安装,mkfs.xfs自动安装在/sbin目录下。
#tar –xvf xfsprogs-2.0.3.src.tar.gz
#cd xfsprogs-2.0.3src
#./configure
#make
#make install
使用mkfs.xfs格式化磁盘为xfs文件系统,方法以下:
# /sbin/mkfs.xfs /dev/sda6 #说明:将分区格式化为xfs文件系统,如下为显示内容:
meta-data=/dev/sda6 isize=256 agcount=8, agsize=128017 blks
data = bsize=4096 blocks=1024135, imaxpct=25
= sunit=0 swidth=0 blks, unwritten=0
naming =version 2 bsize=4096
log =internal log bsize=4096 blocks=1200
realtime =none extsz=65536 blocks=0, rtextents=0
格式化磁盘时,若是mkfs.xfs提示你分区本来已被格式化为其它文件系统,可使用参数 –f 强行格式化:
#/sbin/mkfs.xfs –f /dev/sda6
加载XFS文件系统
#mount –t xfs /dev/sda6 /xfs
其中/xfs是主分区/下的一个目录。
最后,为了让系统启动后就自动加载,应该更改/etc/fstab,这样系统启动后就会自动加载xfs分区而没必要每次都手工加载。
要说明的一点是目前的xfs因为受linux内存页限制,在x86版本中,只能实现文件系统的块尺寸为4K。另外,XFS文件系统能够不一样的方式 mount,即容许文件系统以读方式加载,也容许以读写方式加载。这是由于xfs文件系统用做根文件系统时,为了安全要以只读方式加载。
文件系统的迁移
要使得系统中的其它分区使用XFS文件系统,还有一步是迁移文件系统。建议在迁移文件系统时,首先将磁盘上的数据、文件先备份,以避免发生不可挽回的损失,在进行文件系统转换之间,最好能将整个系统进行彻底备份。这一步有不少种方法,本文仅就笔者的迁移方法加以描述。各位能够按照本身习惯的方式去完成
若是你想获得一个纯的xfs系统(系统的全部文件系统均采用XFS文件系统)话,还得将根文件系统也格式化为xfs文件系统。这其实是比较繁杂的一步。由于根文件系统不能被umount,因此,必须首先建立一个分区,其文件系统为ext2文件系统,而后将目前的根分区上的全部文件与目录,原本来本地复制到这一个分区,而后更改/etc/fstab文件,替换原来的根分区。
方法以下:
$ mkfs -t ext2 /dev/hda4
$ mkdir /mnt/temp
$ mount -t ext2 /dev/hda4 /mnt/temp
$ cd /
$ tar lcvf - .|(cd /mnt/temp; tar xpvf - )
以上操做是将根分区上的全部文件打包,复制到新创建的分区。固然,你也能够直接使用如下命令复制文件。
# cp –dpR / /mnt/temp
接着,将下次启动的根分区更改到/dev/hda4分区,更改/etc/fstab文件及/etc/lilo.conf ,而后,运行 lilo.
从新启动后,新的根分区就已经为/dev/hda4。
接下来,建立一个xfs文件系统的分区:
$ mkfs -t xfs /dev/hda2
加载此分区,采用两样的方法,将根分区的内容复制到此分区
$ mount -t xfs /dev/hda2 /mnt/temp
在根分区下,运行
$ cd /
$ tar lcvf - .|(cd /mnt/temp; tar xpvf - )
再次更改/etc/fstab、/etc/lilo.conf,用新建的xfs分区替换原来的ext2主分区。以下所示:
/dev/hda2 / xfs defaults 1 1
将新建的xfs分区用做根分区,保存以上设置。再次检查配置文件内容,确认无误后再从新启动系统。若是你的设置所有正确,那么系统成功启动后,你就拥有一个纯XFS文件系统的系统了。