设为首页 收藏本站
查看: 1778|回复: 0

[经验分享] moosefs2.0初探及部署

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-23 10:22:30 | 显示全部楼层 |阅读模式
前言:分布式文件系统是大型网站的必用架构,我们公司网站升级的时候考虑使用分布式文件系统,最初考虑使用fastdfs,但是性能不足,hdfs配置复杂,所以使用了moosefs文件系统。moosefs配置简单,并且性能也不错,唯一缺点就是master单点故障问题,不过1.6以上版本使用了metalogger server,它会定时把master上的meta数据下载到本机上,故障发生时,可以实现恢复。对于恢复这块,我会在后续的文章中给出比较完善的解决方案。此博还附带有moosefs2.0的tar包,需要的小伙伴可以下载,因为我在写这篇博客的时候,www.moosefs.org,打开速度太慢。以下是正文。

Moosefs原理原理图 wKioL1ZOyw_iKbSzAABqcjvWo8c800.jpg
wKiom1ZOyrvwfPqyAACNlryyuDA866.jpg
    从上图可以看到master是整个系统的大脑,它知道数据被分成了多少份,放在那个服务器上的那个位置,client每次访问都要经过master。chunk是数据真正存放的地方。

实现过程   Master负责整个系统数据的管理,保存数据分成多少份,在那个服务器存放等信息;metalogger会定时备份master的管理数据,master故障后,通过metalogger的备份数据,可以实现系统的恢复;chunk server是数据真正的存放位置,数据会被分成多份chunk放在chunk server中;client端是分布式系统的使用者,系统搭建成功后,可以把系统像挂载硬盘一样挂载在client上,实现系统的分布式应用。
安装规范:1、moosefs源码文件包统一放在所有服务器的/usr/local/src下
2、创建独立的运行用户:mfs
3、安装目录为:/usr,配置文件路径为:/etc/mfs,
4、Chunk server的存储路径为/mfschunk
5、Client 端的挂载点为/mnt/mfs
6、Master和chunk server的启动加入到/etc/rc.local文件中,使其随开机启动
安装过程Master端1、把tar包上传到/usr/loca/src下
2、在/etc/hosts文件中填入一下内容:“IP mfsmaster”(其中IP为master的ip地址)
wKioL1ZO0JKjOva2AAAT3VlFjBg224.jpg
3、添加mfs用户:useradd mfs
4、解包:tar xf moosefs-2.0.81-1.tar.gz
5、进入安装目录:cd moosefs-2.0.81
6、编译安装:./configure--prefix=/usr --sysconfdir=/etc --localstatedir=/var/lib--with-default-user=mfs --with-default-group=mfs --disable-mfschunkserver--disable-mfsmount
7、编译:make&&make install
8、# cd/etc/mfs/更改配置文件名称:
把原来的文件名改为cfg文件
# cp mfsmaster.cfg.dist mfsmaster.cfg
#cp mfsmetalogger.cfg.dist mfsmetalogger.cfg
#cp mfsexports.cfg.dist mfsexports.cfg
#cp mfstopology.cfg.dist mfstopology.cfg
9、启动master:/usr/sbin/mfsmasterstart
Metalogger server端1、把tar包上传到/usr/loca/src下
2、在/etc/hosts文件中填入一下内容:“IP mfsmaster”(其中IP为master的ip地址)
3、添加mfs用户:useradd mfs
4、解包:tar xf moosefs-2.0.81-1.tar.gz
5、进入安装目录:cd moosefs-2.0.81
6、编译安装:./configure--prefix=/usr --sysconfdir=/etc --localstatedir=/var/lib--with-default-user=mfs --with-default-group=mfs --disable-mfschunkserver--disable-mfsmount
7、编译:make&&makeinstall
8、启动metaloggerserver:/usr/sbin/mfsmetalogger start
Chunk server端1、把tar包上传到/usr/loca/src下
2、在/etc/hosts文件中填入一下内容:“IP mfsmaster”(其中IP为master的ip地址)
3、添加mfs用户:useradd mfs
4、解包:tar xf moosefs-2.0.81-1.tar.gz
5、进入安装目录:cd moosefs-2.0.81
6、编译安装:./configure--prefix=/usr --sysconfdir=/etc --localstatedir=/var/lib--with-default-user=mfs --with-default-group=mfs --disable-mfsmaster
7、编译:make&&makeinstall
8、更改配置文件名称:
#cd /etc/mfs
#cp mfschunkserver.cfg.dist mfschunkserver.cfg
#cp mfshdd.cfg.dist mfshdd.cfg
#cp mfsmetalogger.cfg.dist mfsmetalogger.cfg
9、创建目录:mkdir /mfschunk
10、修改权限 chmod –R mfs:mfs /mfschunk
11、修改配置文件:在/etc/mfs/mfshdd.cfg文件中添加内容:/mfschunk
wKioL1ZO0DuyxsPqAAB0O1yvbgk004.jpg
12、启动chunk server:/usr/sbin/mfschunkserverstart
Client 端1、安装fuse:yum install –y fuse*
2、在/etc/hosts文件中填入一下内容:“IP mfsmaster”(其中IP为master的ip地址)
3、把tar包上传到/usr/loca/src下
4、解包:tar xf moosefs-2.0.81-1.tar.gz
5、进入安装目录:cd moosefs-2.0.81
6、编译安装:./configure--prefix=/usr --sysconfdir=/etc --localstatedir=/var/lib--with-default-user=mfs --with-default-group=mfs --disable-mfsmaster--disable-mfschunkserver
7、编译:make&&makeinstall
8、挂载文件系统:/usr/bin/mfschunk/mnt/mfs –H mfsmaster
9、使用df -h 查看,出现类似如下内容说明安装成功
wKiom1ZOzwaDJ-2_AABHP5F5kFU933.jpg
现在就可以像使用普通硬盘一样,使用整个文件系统了。
总结:moosefs故障后,只能通过手动的方式来解决,网上有说法搭配keepalived可是实现自动切换,做到无延时故障处理,这个我没有实验,我会在后续的文章中继续探讨moosefs的故障问题。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-142525-1-1.html 上篇帖子: MooseFS 分布式文件介绍+部署 MFS 下篇帖子: Salt实战之自动安装部署MooseFS
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表