新增三台centos7机器,最小化安装
ip分配是 服务端192.168.1.7 192.168.1.8 客户端192.168.1.9
主机名分别为 gluster01 gluster02 client01
hostnamectl set-hostname gluster01
hostnamectl set-hostname gluster02
hostnamectl set-hostname client01
配置所有机器网络,要求能访问外网(略)
关闭防火墙和selinux
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
sed -i 's/enforcing/disabled/g' /etc/selinux/config
修改所有机器的hosts文件,添加对应的ip主机名解析
vi /etc/hosts
192.168.1.7 gluster01
192.168.1.8 gluster02
192.168.1.9 client01
配置yum源
cd /etc/yum.repos.d/
wget http://mirrors.aliyun.com/repo/Centos-7.repo
wget http://mirrors.aliyun.com/repo/epel-7.repo
yum -y install epel-release
安装服务端
yum install centos-release-gluster -y
yum install -y glusterfs glusterfs-server glusterfs-fuse
systemctl start glusterd
systemctl enable glusterd
在节点gluster01上,配置整个GlusterFS集群,把各个节点加入到集群
gluster peer probe gluster01
gluster peer probe gluster02
查看集群状态
gluster peer status
在两个服务节点上创建数据存储目录
mkdir -p /usr/local/share/models
在gluster01上创建GlusterFS磁盘
加上replica 2 就是2个节点中,每个节点都要把数据存储一次,就是一个数据存储2份,每个节点一份
如果不加replica 2,就是2个节点的磁盘空间整合成一个硬盘
gluster volume create models replica 2 gluster01:/usr/local/share/models gluster02:/usr/local/share/models force
启动集群
gluster volume start models
安装客户端
yum install -y glusterfs glusterfs-fuse
mkdir -p /mnt/models
挂载
mount -t glusterfs -o rw gluster01:models /mnt/models/
df查看
文件系统 1K-块 已用 可用 已用% 挂载点
/dev/sda2 18244432 1012448 16282176 6% /
devtmpfs 491416 0 491416 0% /dev
tmpfs 500680 0 500680 0% /dev/shm
tmpfs 500680 6792 493888 2% /run
tmpfs 500680 0 500680 0% /sys/fs/cgroup
/dev/sda1 194235 95079 84820 53% /boot
tmpfs 100136 0 100136 0% /run/user/0
gluster01:models 18244352 1012480 16282112 6% /mnt/model
其他操作命令
删除GlusterFS磁盘
# gluster volume stop models 先停止
# gluster volume delete models 再删除
卸载GlusterFS磁盘
gluster peer detach gluster02
ACL访问控制
gluster volume set models auth.allow 192.168.1.*,192.168.2.*
添加GlusterFS节点
# gluster peer probe gluster03
# gluster peer probe gluster04
# gluster volume add-brick models gluster03:/data/gluster gluster04:/data/gluster
迁移GlusterFS数据
# gluster volume remove-brick models gluster01:/usr/local/share/models gluster03:/usr/local/share/models start
# gluster volume remove-brick models gluster01:/usr/local/share/models gluster03:/usr/local/share/models status
# gluster volume remove-brick models gluster01:/usr/local/share/models gluster03:/usr/local/share/models commit
修复GlusterFS数据(在节点1宕机的情况下)
# gluster volume replace-brick models gluster01:/usr/local/share/models gluster03:/usr/local/share/models commit -force
# gluster volume heal models full