接触到glusterfs,在centos7上安装集群,记录下。
如下List-1所示三台机器,hostname分别是node1/node2/node3,之后将List-1的内容写入/etc/hosts
List-1
192.168.33.20 node1
192.168.33.21 node2
192.168.33.22 node3
安装glusterfs(三台都要执行)
List-2
#安装glusterfs
yum install centos-release-gluster
yum install -y glusterfs glusterfs-server glusterfs-fuse glusterfs-rdma
#启动gluster服务
systemctl start glusterd.service
systemctl enable glusterd.service
#关闭防火墙
systemctl stop firewalld.service
systemctl disable firewalld.service
在node1上执行如下List-3,将node2、node3加入集群
List-3
gluster peer probe node2
gluster peer probe node3
在node1上看集群状态,如下List-4
List-4
[root@node1 db]# gluster peer status
Number of Peers: 2
Hostname: node2
Uuid: ab8dac2f-e5fb-4752-b70d-b0103a40f8ea
State: Peer in Cluster (Connected)
Hostname: node3
Uuid: f13b4732-ae12-4b6c-b4eb-65fd7886588c
State: Peer in Cluster (Connected)
到这里,我们可以直接创建卷来使用,但是我们想将卷挂载到分区中,所以还需要额外的操作。如下List-7,卷/dev/sdb是我新增的裸磁盘——virtualbox上通过UI新增的。
List-7
[root@node1 db]# fdisk -l
Disk /dev/sda: 10.5 GB, 10485760000 bytes, 20480000 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0x000927b6
Device Boot Start End Blocks Id System
/dev/sda1 * 2048 1026047 512000 83 Linux
/dev/sda2 1026048 20479999 9726976 8e Linux LVM
Disk /dev/sdb: 3221 MB, 3221225472 bytes, 6291456 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
...
如下List-8,由于/dev/sdb是3G的,所以我申请2G,每个节点都要执行
List-8
vgcreate vg_gluster /dev/sdb
lvcreate -n lv_gluster -L 2G vg_gluster
#格式化
mkfs.ext4 /dev/vg_gluster/lv_gluster
将/data_gluster挂载到我们创建的盘,如下List-9,每个节点都要执行
List-9
echo "/dev/vg_gluster/lv_gluster /data_gluster ext4 defaults 0 0" >> /etc/fstab
mount -a
mount -l | grep gluster
之后在node1/node2/node3上手动创建目录/data_gluster。
在node1上,用如下List-5命令创建卷,卷名称是db_volume
List-5
gluster volume create db_volume \
replica 3 node1:/data_gluster/db node2:/data_gluster/db node3:/data_gluster/db force
激活卷,如下List-6
List-6
gluster start db_volume
到这里,我们虽然激活了卷,但是还不能直接使用,要将其挂载出来,如下List-10,将卷db_volume挂载到/mnt/gluster/db目录下,我们只能往/mnt/gluster/db里面写数据,不能直接操作/data_gluster,这个步骤在node1上执行。后面不想挂载/mnt/gluster/db时可以用"umount -l /mnt/gluster/db"
List-10
mkdir -p /mnt/gluster/db
mount -t glusterfs node1:/db_volume /mnt/gluster/db
Reference
- 结合实践,部分参考了这边文章: https://blog.youkuaiyun.com/phn_csdn/article/details/75153913