转发:http://quenywell.com/install-glusterfs-on-centos-6-x/
本文主要介绍如何在CentOS 6.x上快速安装GlusterFS。
GlusterFS是一个开源的分布式文件系统,它可以将分散的存储空间聚合在一起,形成一个虚拟的存储池。它支持横向扩展(Scale-Out),可通过增加存储节点来提升整个系统的容量或性能,存储容量可扩展至PB级。这一扩展机制是目前的存储技术热点,能有效应对容量、性能等存储需求。
GlusterFS除了支持
分散存储(Distributed,将不同的文件放在不同的存储节点)之外,
还支持镜像存储(Replicated,同一个文件存放在两个以上的存储节点) 和
分片存储(Stripped,将一个文件分划分为多个固定长度的数据,分散存放在所有存储节点)。
-
事前准备
准备三台机器(物理机或者虚拟机均可)用于安装和测试GlusterFS,其中两台用作服务器,一台用作客户端,主机名分别为:
server1.quenywell.com
server2.quenywell.com
client.quenywell.com
-
安装GlusterFS
-
在每台机器上安装GlusterFS的源(repo):
wget -P /etc/yum.repos.d http://download.gluster.org/pub/gluster/glusterfs/LATEST/CentOS/glusterfs-epel.repo
-
在服务器server1和server2上安装服务端软件:
# yum -y install glusterfs-server glusterfs glusterfs-fuse
启动GlusterFS服务:
# /etc/init.d/glusterd start
设置GlusterFS随系统启动:
# chkconfig glusterd on
-
在client上安装客户端软件:
# yum -y install glusterfs glusterfs-fuse
-
GlusterFS服务器设置
-
加入可信存储池(Trusted Storage Pool)
在server1上运行以下命令: #通过hostname访问对端peer,建议配置hostname(若不配置hostname,迁移场景IP变化时,就麻烦了)
# gluster peer probe server2
Probe successful
查看状态:
# gluster peer status
Number of Peers: 1
Hostname: server2.quenywell.com
Uuid: c191b17b-ab9d-4b15-a70d-dcc92be067c9
State: Peer in Cluster (Connected)
-
创建GlusterFS逻辑卷(Volume)
在server1和server2分别建立/data目录:(两台要一致的目录,否则下面创建volume会不成功,而且不能在 / 下的目录)
# mkdir /data
然后执行以下命令(只需要在其中一台服务器上执行即可,本例使用server1):
# gluster volume create gv0 replica 2 server1:/data server2:/data
Creation of volume gv0 has been successful. Please start the volume to access data.
这条命令的意思是使用Replicated的方式,建立一个名为gv0的卷(Volume),存储块(Brick)为2个,分别为server1:/data和server2:/data。
启用GlusterFS逻辑卷:
# gluster volume start gv0
Starting volume gv0 has been successful
查看逻辑卷状态:
# gluster volume info
Volume Name: gv0
Type: Replicate
Volume ID: 5429d6c1-44e5-43ad-a495-0a1f5b6d774b
Status: Started
Number of Bricks: 1 x 2 = 2
Transport-type: tcp
Bricks:
Brick1: server1.quenywell.com:/data
Brick2: server2.quenywell.com:/data
-
GlusterFS客户端连接
在客户端client.quenywell.com上使用mount命令,把服务器上新建的GlusterFS逻辑卷gv0挂载到本地目录/mnt/glusterfs上:
# mkdir /mnt/glusterfs
mount -t glusterfs server1.quenywell.com:/gv0 /mnt/glusterfs
确认挂载结果:
# mount -t fuse.glusterfs
出现以下类似信息即表示挂载成功:
server1.quenywell.com:/gv0 on /mnt/glusterfs type fuse.glusterfs (rw,default_permissions,allow_other,max_read=131072)
如果希望系统重启后可以自动挂载,在/etc/fstab文件中加入此行:
server1.quenywell.com:/data /mnt/glusterfs glusterfs defaults,_netdev 0 0
-
客户端测试
client端成功挂载逻辑卷之后,在挂载目录/mnt/glusterfs建立文件以测试GlusterFS是否正常工作。
# cd /mnt/glusterfs
# touch file1 file2 file3
# ls -l
-rw-r--r-- 1 root root 0 Nov 11 14:31 file1
-rw-r--r-- 1 root root 0 Nov 11 14:31 file2
-rw-r--r-- 1 root root 0 Nov 11 14:31 file3
因为创建卷gv0的时候使用的是镜像存储(Replicated),所以在gv0上写入的文件应该同时出现在两个服务器的/data目录上。
在server1和server2查看/data目录,可以看到两个服务器均出现这三个文件:
[root@server1]# ls -l
-rw-r--r-- 1 root root 0 Nov 11 14:31 file1
-rw-r--r-- 1 root root 0 Nov 11 14:31 file2
-rw-r--r-- 1 root root 0 Nov 11 14:31 file3
[root@server2]# ls -l
-rw-r--r-- 1 root root 0 Nov 11 14:31 file1
-rw-r--r-- 1 root root 0 Nov 11 14:31 file2
-rw-r--r-- 1 root root 0 Nov 11 14:31 file3
自此GlusterFS快速安装过程结束。如果需要了解更多有关GlusterFS的知识,敬请关注科威网后续相关文章。
(完)