ubuntu glusterfs 安装和配置(二)

1 前言相关

1.1 glusterfs优势

1、无元数据设计
GlusterFS设计没有集中或分布式元数据,取而代之的是弹性哈希算法。集群中的任何服务器、客户端都可利用哈希算法、路径及文件名进行计算,就可以对数据进行定位,并执行读写访问操作。

结论:

  • 无元数据设计带来的好处是极大地提高了扩展性,同时也提高了系统的性能和可靠性。
  • 如果需要列出文件或目录,性能会大幅下降,因为列出文件或目录,需要查询所在的节点并对节点中的信息进行聚合。
  • 但是如果给定确定的文件名,查找文件位置会非常快。

2、服务器间的部署
GlusterFS集群服务器之间是对等的,每个节点服务器都掌握了集群的配置信息。
所有信息都可以在本地查询。每个节点的信息更新都会向其他节点通告,保证节点信息的一致性。
但是集群规模较大后,信息同步效率会下降,非一致性概率会提高。

3、客户端访问
首先程序通过访问挂载点的形式读写数据,对于用户和程序而言,集群文件系统是透明的,用户和程序根本感觉不到文件系统是本地还是远端服务器上。

读写操作会被交给VFS(Virtual File System,虚拟文件系统) 来处理,VFS会将请求交给FUSE内核模块,而FUSE又会通过设备/dev/fuse将数据交给GlusterFS Client。最后经过GlusterFS Client计算,并最终通过网络将请求或数据发送到GlusterFS Servers上。

关于glusterfs的原理详情,可以参考以下文章
glusterfs架构和原理
换个视角深入理解GlusterFS,GlusterFS缺点分析
glusterfs中文资料推荐刘爱贵博士的GlusterFS原创资源系列

1.3 volume知识

存储类型介绍详见:Setting Up Volumes - Gluster Docs

在老版本中,共有7种卷类型
在新版本中,共有5种卷类型
共有的卷类型是:

  • Distributed (分布式卷 根据hash结果存放,无备份,可直读)
  • Replicated (复制卷 类似 RAID1,可直读)
  • Distributed Replicated (分布式复制卷 类比 RAID10,可直读)

不同的卷类型是:

  • 老版本中有stripe(条带卷),块存储方式,不能直读
  • 以及基于条带卷组合的分布式条带卷,复制条带卷,分布式复制条带卷
  • 新版本中放弃了stripe,启用了基于EC纠错码的Dispersed(纠错卷)
  • 以及组合出的Distributed Dispersed(分布式纠错卷)

不过我们不用考虑那么多,因为常规都用分布式复制卷,优点如下

  • 分布式存储,效率高
  • 基于复制卷,数据有备份
  • 文件可直读
  • 所有版本都支持

当然Dispersed(纠错卷 类似于RAID5)从3.6开始一直更新到7.x版本,花费了gluster吞对大量心血,想了解的可以看这篇文章

2 服务部署

参考 官方:快速部署指南

2.1 服务规划

操作系统 IP 主机名 附加硬盘
ubuntu16.04 172.18.16.171 node01 sdb:5G
ubuntu16.04 172.18.17.245 node02 sdb:5G
ubuntu16.04 172.18.16.80 node03 sdb:5G
ubuntu16.04 172.18.17.168 node04 sdb:5G

2.2 环境准备

4台服务器都做以下相同操作

# 关闭防火墙、selinux等不解释
#加入防火墙列表:
iptables -I INPUT -p all -s 172.18.17.245  -j ACCEPT
# 完成hosts解析
cat >>/etc/hosts <<EOF
172.18.16.171  node1
172.18.17.245  node2
172.18.16.80   node3
172.18.17.168  node4
EOF

# 安装4.1apt源和程序
apt install software-properties-common

# 添加glusterfs13源
add-apt-repository ppa:gluster/glusterfs-3.13

apt update

# 安装服务器
apt install glusterfs-server

Note: Packages exist for Ubuntu 16.04 LTS, 18.04 LTS, 20.04 LTS, 20.10,
 21.04
# 启动服务并开机启动
update-rc.d glusterd defaults
#或者
systemctl enable glusterd

2.3 格式化挂载磁盘

总共创建3个目录,brick1用来挂载sdb,另外两个目录作为本地文件夹

格式化磁盘

# 查看磁盘列表
[root@gf-node01 ~]# fdisk -l
Disk /dev/sdb: 5368 MB, 5368709120 bytes, 10485760 sectors
Disk /dev/sda: 53.7 GB, 53687091200 bytes, 104857600 sectors

# 不分区直接格式化磁盘
mkfs.xfs  -i size=512 /dev/sdb

挂载磁盘

# 创建目录并挂载
mkdir -p /data/brick{1..3}
echo '/dev/sdb /data/brick1 xfs defaults 0 0' >> /etc/fstab
mount -a && mount
#或者挂载
echo '127.0.0.1:/gv2 /mnt2 glusterfs defaults,_netdev 0 0' >> /etc/fstab

# 查看结果
[root@gf-node01 ~]# df -h|grep sd
/dev/sda2        48G  1.7G   47G   4% /
/dev/sdb        5.0G   33M  5.0G   1% /data/brick1

2.4 建立主机信任池

在任意一台主机上,执行以下命令都可以建立信任池,建立并不需要账号密码,因为默认是将部署环境考虑为安全的可信环境

# 建立可信池【节点加入集群】
gluster peer probe node02
gluster peer probe node03

# 查看状态
[root@gf-node01 ~]# gluster peer status
......
[root@gf-node01 ~]# gluster pool list
UUID                    Hostname    State
4068e219-5141-43a7-81ba-8294536fb054    node02  Connected 
e3faffeb-4b16-45e2-9ff3-1922791e05eb    node03  Connected 
3e6a4567-eda7-4001-a5d5-afaa7e08ed93    localhost   Connected

注意: 一旦信任池建立后,只有在信任池中的节点才能添加新服务器信任池中

3 使用分布式复制卷

只实验GlusterFs的分布式复制卷,其他卷类型有需要的话参考百度自行测试

3.1 分布式复制卷创建说明

  1. 命令gluster volume create gv1 replica 3 DIR1 DIR2 DIR3 ....

  2. 副本数不能小于3 replica 3,否则会阻止创建,因为可能脑裂,会提示

    Replica 2 volumes are prone to split-brain. Use Arbiter or Replica 3 to avoid this
    
    
  3. 副本的数量如果等于副本数(3个),则是分布式卷,是倍数则是分布式复制卷

  4. 会先将3个副本一组创建为复制卷,然后再将多个复制卷组成分布卷

  5. 分布式复制卷的副本顺序,和创建命令相关,不会随机排列

  6. 如果不是所有副本卷都是独立硬盘,需要添加force参数,否则会提示错误

    volume create: gv1: failed: 
    The brick gf-node01:/data/brick2/gv1 is being created in the root partition. It is recommended that you don't use the system's root partition for storage backend. Or use 'force' at the end of the command if you want to override this behavior.
    
    

3.2 分布式复制卷创建

# 创建分布式复制卷
gluster volume create gv1 replica 3 \
  node01:/data/brick1/gv1 \
  node01:/data/brick2/gv1 \
  node02:/data/brick1/gv1 \
  node02:/data/brick2/gv1 \
 node03:/data/brick1/gv1 \
  node03:/data/brick2/gv1 \
  force

# 启动卷 
gluster volume start gv1

# 查看卷的状态
[root@gf-node01 ~]# gluster volume info 
Volume Name: gv1
Type: Distributed-Replicate
Volume ID: e1e004fa-5588-4629-b7ff-048c4e17de91
Status: Started
Snapshot Count: 0
Number of Bricks: 2 x 3 = 6
Transport-type: tcp
Bricks:
Brick1: node01:/data/brick1/gv1
Brick2: node01:/data/brick2/gv1
Brick3: node02:/data/brick1/gv1
Brick4: node02:/data/brick2/gv1
Brick5: node03:/data/brick1/gv1
Brick6: node03:/data/brick2/gv1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on
performance.client-io-threads: off

3.3 分布式复制卷的使用

# 挂载卷
[root@gf-node01 ~]# mount -t glusterfs node01:/gv1 /mnt

# 写入数据测试
[root@gf-node01 ~]# touch /mnt/test{1..9}
[root@gf-node01 ~]# ls /mnt/test{1..9}
/mnt/test1  /mnt/test2  /mnt/test3  /mnt/test4  /mnt/test5  /mnt/test6  /mnt/test7  /mnt/test8  /mnt/test9

# 验证测试数据
[root@gf-node01 ~]# ls /data/brick*/*
/data/brick1/gv1:
test1  test2  test4  test5  test8  test9
/data/brick2/gv1:
test1  test2  test4  test5  test8  test9

[root@gf-node02 ~]# ls /data/brick*/*
/data/brick1/gv1:
test1  test2  test4  test5  test8  test9
/data/brick2/gv1:

[root@gf-node03 ~]# ls /data/brick*/*
/data/brick1/gv1:
test3  test6  test7
/data/brick2/gv1:
test3  test6  test7

结论: 可以看出前三个为一个复制集,后三个为一个复制集,所以创建卷的时候,卷的顺序很关键

3.4 卸载节点

#卸载节点3
 gluster peer detach node03

3.5 卷扩容

#卷 gv1 扩容
 gluster volume add-brick  gv1 node03:/data/brick1 node04:/data/brick1

3.6 开机自启动

systemctl enable glusterd

3.7 自动挂载gluster

#进入下列文件
vi  /etc/fstab
#末尾加上下列行
127.0.0.1:/gv2 /mnt2 glusterfs defaults,_netdev 0 0
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容