moosefs的安装使用及遇到的问题
一、获取源码安装包
到官网下载最新版本moosefs:
https://moosefs.com/download/sources-archive-3-0.html
到官网下载最新版本fuse源码
https://github.com/libfuse/libfuse
也可以下载rpm包:
http://www.rpmfind.net/linux/rpm2html/search.php?query=libfuse-devel
还可以:
yum install -y fuse fuse-devel
二、安装
先添加mfs用户:
[root@localhost mfs]# groupadd mfs
[root@localhost mfs]# useradd -g mfs mfs
然后就是正常的源码安装过程:
[root@local mfs]#./configure --prefix=/usr/local/moosefs --sysconfdir=/etc --localstatedir=/var/lib --with-default-user=mfs --with-default-group=mfs
[root@local mfs]# make
[root@local mfs]# makeinstall
configure中--disable-mfschunkserver --disable-mfsmount --disable-mfsmaster这三个是可选项,比如使用前两个,就表示服务器上只装master,metalogserver和master是一样的。
三、修改配置文件
[root@localhost mfs]# cd /etc/mfs
[root@localhost mfs]# cp mfsmaster.cfg.sample mfsmaster.cfg
[root@localhost mfs]# cp mfsmetalogger.cfg.sample mfsmetalogger.cfg
[root@localhost mfs]# cp mfsexports.cfg.sample mfsexports.cfg
[root@localhost mfs]# vi mfsexports.cfg
* / rw,alldirs,ignoregid,maproot=:,mapall=: [root@localhost mfs]# cd /var/lib/mfs
[root@localhost mfs]# cp metadata.mfs.empty metadata.mfs
[root@localhost mfs]# chown -R mfs:mfs /var/lib/mfs
[root@localhost mfs]# vi /etc/hosts
192.168.1.1 mfsmaster
修改配置文件,基本上是把原来命名的配置文件样例重新命名成标准配置文件;
mfsexports.cfg中的配置文件,是为了赋予访问权限;
/etc/hosts中标识master的ip,是为了给mfscgiserv和mfschunkserver找mfsmaster用的。
四、启动和停止
启动:
[root@lh mfs]# mfsmaster start
[root@lh mfs]# mfscgiserv start
[root@lh mfs]# mfsmetalogger start
[root@lh mfs]# mfschunkserver start
停止:
[root@lh mfs]# mfsmaster stop
[root@lh mfs]# mfscgiserv stop
[root@lh mfs]# mfsmetalogger stop
[root@lh mfs]# mfschunkserver stop
五、mfs的使用
安装好后就到有mfsmount的的服务器上挂载一个本地目录:(后面跟的是master的ip)
[root@lh mfs]mfsmount /mnt/mfs/ -H 192.168.1.1
其实本身mfsmount就相当于是一个客户端。使用的时候就把挂载的目录当成本地的磁盘目录一样使用即可。不过此目录使用的是mfschunk上的空间,而操作这个云文件系统的命令都封装在在mfstool中:
[root@lh mfs]# man mfstools
Mossefs整个系统的状态(mfschunk、mfsmaster、mfsmount、mfsmetalogger和文件等)的状态都可以用mfs自带的cgi查看,网址:
" http://ip.to.mfscgi.server:9425/ "
其中goal表示一个文件复制了几份,copy表示文件放在了几个服务器上,这些也都可以用mfstools中的fileinfo和checkfile命令查看。
六、mfs见过的错误和解决方法
1、mfsmount取消挂载的问题:
ps -ef | grep mfsmount
fuser -m -k -i [mfsmountpid]
如果不行就
kill - [mfsmountpid]
如果df或者访问/path/to/mountdir卡死,那么就
umount -l /mnt/mfs
然后killall mfsmount
当然卡死也有可能是由于与服务端网络不通断开连接,这种情况下kill掉mfsmount会导致mfsmount编程僵尸进程,
所以建议在mfsmount时加上参数-o mfstimeout N来指定IO出错的超时时间。
2、新加的服务器死活连到master上都是disconnect的状态
到mfschunkserver所在的服务器:
[root@lh mfs]#tail -100f /var/log/message
[root@lh mfs]#Aug :: localhost mfschunkserver[]: connected to Master
[root@lh mfs]#Aug :: localhost mfschunkserver[]: MATOCS_MASTER_ACK - wrong meta data id. Can't connect to master
那么就清空/var/lib/mfs目录,
然后到好的chunkserver的disk(也就是mfschunk1,2,3之类的)目录下复制".metaid"文件到目标disk,问题就可以解决了。
3、权限问题
can't create lockfile in working directory: Permission denied
[root@lh mfs]# chown -R mfs:mfs /path/to/thatdir
4、目录非空
fuse: mountpoint is not empty
那就删了再来,或者换个目录,或者修复:
fsck -y /dev/sda1
moosefs的安装使用及遇到的问题的更多相关文章
- 在CentOS上安装部署MooseFS分布式文件系统
参考资料: http://www.moosefs.org/tl_files/manpageszip/moosefs-step-by-step-tutorial-cn-v.1.1.pdf 环境介绍:OS ...
- [moosefs] storage class
chapter 1 moosefs 3.1 storage class 功能的介绍 1.1 什么是storage class 在moosefs中,storage class允许指定文件的chunks存 ...
- MooseFS技术详解
原文 http://www.tuicool.com/articles/vQvEZ3y MooseFS是一款具有冗余容错功能的分布式文件系统.它把数据分散在多台服务器上,确保一份数据多个备份副本,对外提 ...
- Rhel6-moosefs分布式存储配置文档
MFS 特性: 1. Free(GPL) 2. 通用文件系统,不需要修改上层应用就可以使用 3. 可以在线扩容,体系架构可伸缩性极强. 4. 部署简单. 5. 高可用,可设置任意的文件冗余程度(提供比 ...
- centos7 MFS drbd keepalived
环境: centos7.3 + moosefs 3.0.97 + drbd84-utils-8.9.8-1 + keepalived-1.2.13-9 工作原理: 架构图: 节点信息: 节点名 ...
- 分布式文件系统MooseFS安装步骤
1. 安装 1.1 准备安装环境 首先选择一台比较好的服务器做master,如果可以在选择一台做为master的备份服务器最好.然后其他的服务器当chunkserver. 为了方便说明问题,我这 ...
- MooseFS安装部署
环境信息 Master服务器 dev04 chunkserver服务器 dev02.dev03.dev04 metalogger服务器 dev03 mount客户端 dev01.dev02 安装前下载 ...
- MooseFS基础和安装
一.MooseFS简介 1.介绍 MooseFS是一个具备冗余容错功能的分布式网络文件系统,它将数据分别存放在多个物理服务器单独磁盘或分区上,确保一份数据有多个备份副本.对于访问的客户端或者用户来说, ...
- MooseFS分布式文件系统介绍及安装教程详解
MFS系统由4个部分构成:master.metalogger.chunkserver.client. 1.Master —— mfs的大脑,记录着管理信息,比如:文件大小,存储的位置,份数等,和inn ...
随机推荐
- java反编译获取源码
最近在研究反射,想做一个东西,把运行的java程序饭编译(Decompile)成.java文件.现思路如下: 1.写出程序反编译一个类 2.将所有类反编译 3.java代码注入一个正在运行的java程 ...
- 《More Effective C#》读书笔记
<More Effective C#>这本书,大概是四年前看完的,但只整理了一部分读书笔记,后面有时间的话,会陆续补充的. More Effective C# :使用泛型 More Eff ...
- 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用
学习 EF Code First+MVC 时遇到了在请求JsonResult时出现 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用 的异常,原因 ...
- VS2010中整理代码快捷键
快捷键:Ctrl+A Ctrl+K Ctrl+F的三个的组合2015-11-08
- 初识android中的动画
动画效果可以大大提高界面的交互效果,因此,动画在移动开发中的应用场景较为普遍.掌握基本的动画效果在成熟的软件开发中不可或缺.除此之外,用户对于动画的接受程度远高于文字和图片,利用动画效果可以加深用户对 ...
- iOS HTML 字符串中的图片 自适应大小
本文原文地址:http://www.cnblogs.com/qianLL/p/6095988.html 有时候 我们接收数据的时候 后台给的数据室一串HTML 的字符串 但是 我们要显示出来 这 ...
- linux内存使用计算方式
Linux开机后,使用top命令查看,4G物理内存发现已使用的多大3.2G,占用率高达80%以上: Mem: 3889836k total, 3341868k used, 547968k free, ...
- 关于UIApplication单例传值
由于UIApplication的是一个系统级别的单例,那么就能够省去自己创建单例的方法,将需要需要的类对象,在UIApplication单例内声明一个,通过点语法来实现单个 需要调用的实现单例模式的类 ...
- String.Empty、null、“” 区别
概念准备: 1.引用类型是将对象是实际数据保存在堆中, 将对象在堆中的地址保存在栈中. 2.值类型直接将实际数据存放在堆中,不会将对象在堆中的地址保存在栈中. 一.String.Empty和" ...
- union和union all用法
工作中,遇到同事之前写的oracle语句中有一个union all,并且很多地方都用到了.便在网上查了一下用法,以下是自己的理解. union (联合)将两个或者多个结果集合并. 在使用时,两个结果 ...