回顾

文件或目录的额外属性(noower,noattracache和noentrycache),可以通过MFS提供的命令(mfsgeteattr,mfsseteattr,mfsdeleattr等)检查、设置和删除。其行为类似于mfsgettoal/mfssetgoal或者mfsgettrashtime/mfssettrashtime。

维护MFS

维护MFS,最重要的是维护元数据服务器,而元数据服务器最重要的目录就是为/usr/local/mfs/var/mfs(源码安装就在这里)。MFS数据的存储、修改和更新操作变化都会记录在这个目录的某个文件中、因此要保证这个目录的数据安全,就能保证整个MFS文件系统的安全性和可靠性。

/usr/local/mfs/var/mfs目录下的数据由两部分组成:一部分是元数据服务器的改变日志文件,文件名是changelog.*.mfs:另一个部分就是元数据文件metadata.mfs,运行mfsmaster时该文件就会被命名为metadata.mfs.back。只要保证了这两部书的数据安全,即使管理服务器操作破坏,也可以通过备份的元数据文件重新部署一套。

启动MFS集群

最安全的启动MFS集群(避免任何读写错误数据或者类似的问题)步骤如下:

  1. 启动mfsmaster进程。
  2. 启动所有的mfschunkserver进程
  3. 启动mfsmetalogger进程(如果有mfsmetalogger服务器的话)

当所有的数据存储服务器连接到MFS管理服务器后,任何数目的客户端都可以利用mfsmount去连接共享出来的文件系统(可以通过mfscgiserver提供的web界面查看或者mfsmaster日志)

停止MFS集群。

安全停止MFS集群,按照如下步骤进行操作:

  1. 在所有的客户端卸载MFS文件系统(利用umount命令即可卸载)。
  2. 利用mfschunkserver stop停止数据存储服务器进程。
  3. 利用mfsmetalogger stop停止元数据日志服务器进程。
  4. 利用mfsmaster stop停止管理服务器进程。

MFS存储服务器的维护

假如每个文件的goal(副本)都不小于2,并且没有under-goal文件(这些可以通过“mfsgetgoal -r”和mfsdirinfo命令来查看),那么一个数据存储服务器在任何时候都可以停止或重新启动。以后每当需要停止或者重新启动另一个数据存储服务器的时候,需要确定之前的数据存储服务器被链接,而且没有under-goal chunks。

MFS元数据备份

  1. 主要元数据文件metadata.mfs,在MFS的管理服务器master运行时会被命名为metadata.mfs.back。
  2. 元数据改变日志changelog.*.mfs,存储过去N小时内的文件改变(N数值是由BACK_LOGS参数设置的。参数设置在mfschunkserver.cfg配置文件中进行)

主要的元数据文件需要定期备份,备份的频率取决于多少个小时改变日志的存储。元数据改变日志应该时时的自动复制。从MFS1.6.5版本后,这两项任务都是由元数据日志服务器进程完成的。

MFS管理服务器的恢复

一旦服务器奔溃,需要最后一个元数据改变日志changelog和主要的元数据文件metadata.mfs。这个操作可以通过mfsmaster(在1.7版本以前用mfsmetarestore)命令来完成。命令如下所示:

[root@localhost mfs]# mfsmaster -a   #执行这个命令的时候,确保mfsmaster进程处于停止状态。
working directory: /usr/local/mfs/var/mfs # 源码安装指定了/usr/local/mfs,那么默认是在这里。

关于恢复的时候指定元数据存储目录,我这也没发现用哪个命令去指定,在1.7版本以前的是mfsmetarestore -d来指定的。

从备份恢复MFS管理服务器。

为了从备份中恢复一个管理服务器,需要以下步骤进行:

  1. 安装一个新管理服务器。
  2. 利用通配的配置来配置新管理服务器(利用备份找回mfsmaster.cfg),配置文件需要备份的。
  3. 找回metadata.mfs.back文件,从备份服务器中找,也可以从元数据日志服务器中找(如果启动了元数据日志服务),然后把metadata.mfs.back文件放入mfs的数据目录下,源码安装的一般为${prefix}/var/mfs。
  4. 从管理服务器宕机之前任何运行元数据日志服务器上复制最后一个changelog.*.mfs文件,放入管理服务器的数据目录。
  5. 利用mfsmaster -a来合并元数据日志,自动恢复模式。

通过冗余实现失败防护的解决方案。

如题所示,其实就是一主一备的模式,当主的宕机后,备用机马上顶上去。

对于高可用的方案,我们可以采用keepalived或者heartbeat来做高可用。

对于元数据的一致性,我们还可以通过unison来做主备之间的双向元数据的同步,确保数据一致。

MooseFs-分布式文件系统系列(四)之简单聊聊MFS的日常维护的更多相关文章

  1. 在CentOS上安装部署MooseFS分布式文件系统

    参考资料: http://www.moosefs.org/tl_files/manpageszip/moosefs-step-by-step-tutorial-cn-v.1.1.pdf 环境介绍:OS ...

  2. MFS分布式文件系统

    一.MFS概述: MooseFS(moose 驼鹿)是一款网络分布式文件系统.它把数据分散在多台服务器上,但对于用户来讲,看到的只是一个源.MFS也像其他类unix文件系统一样,包含了层级结构(目录树 ...

  3. FastDFS分布式文件系统

    FastDFS分布式文件系统 阅读目录 相关文章 1 分布式文件系统介绍 2 系统架构介绍 3 FastDFS性能方案 4 Linux基本命令操作 5 安装VirtualBox虚拟机并配置Ubuntu ...

  4. MooseFS分布式文件系统介绍及安装教程详解

    MFS系统由4个部分构成:master.metalogger.chunkserver.client. 1.Master —— mfs的大脑,记录着管理信息,比如:文件大小,存储的位置,份数等,和inn ...

  5. 分布式文件系统MFS(moosefs)实现存储共享(第二版)

    分布式文件系统MFS(moosefs)实现存储共享(第二版) 作者:田逸(sery@163.com) 由于用户数量的不断攀升,我对访问量大的应用实现了可扩展.高可靠的集群部署(即lvs+keepali ...

  6. 分布式文件系统MFS(moosefs)实现存储共享(一)

    分布式文件系统MFS(moosefs)实现存储共享 作者:田逸(sery@163.com) from:[url]http://net.it168.com/a2009/0403/270/00000027 ...

  7. 分布式文件系统MFS(moosefs)实现存储共享

    分布式文件系统MFS(moosefs)实现存储共享(第二版) 作者:田逸(sery@163.com) 由于用户数量的不断攀升,我对访问量大的应用实现了可扩展.高可靠的集群部署(即lvs+keepali ...

  8. 分布式系列四: HTTP及HTTPS协议

    分布式系列四: HTTP及HTTPS协议 非常全面的一篇HTTP的文章: 关于HTTP协议,一篇就够了 还有一个帮助理解HTTPS的文章: 也许,这样理解HTTPS更容易 本文的一些描述摘自这篇文章 ...

  9. Hive数据导入——数据存储在Hadoop分布式文件系统中,往Hive表里面导入数据只是简单的将数据移动到表所在的目录中!

    转自:http://blog.csdn.net/lifuxiangcaohui/article/details/40588929 Hive是基于Hadoop分布式文件系统的,它的数据存储在Hadoop ...

随机推荐

  1. 在eclipse中使用第三方库总结

    一.建立user library 导入第三方jar文件,最简单的方式是:右键工程/属性/java build path/add external jars. 另一种方式是:window/prefren ...

  2. confluence的安装、备份和恢复(wiki)

    还有一种比较不错的wiki工具MediaWiki 安装教程参考 http://pangge.blog.51cto.com/6013757/1560249 我是按照上面的教程搭建的 还有几篇不错的文章 ...

  3. ActiveMQ_点对点队列(二)

      一.本文章包含的内容 1.列举了ActiveMQ中通过Queue方式发送.消费队列的代码(普通文本.json/xml字符串.对象数据) 2.spring+activemq方式   二.配置信息 1 ...

  4. 【BZOJ 3053】The Closest M Points

    KDTree模板,在m维空间中找最近的k个点,用的是欧几里德距离. 理解了好久,昨晚始终不明白那些“估价函数”,后来才知道分情况讨论,≤k还是=k,在当前这一维度距离过线还是不过线,过线则要继续搜索另 ...

  5. 转自文翼的博客:将本地时间转换为 GMT 时间

    在写 RSS 订阅接口的时候,发现最终输出文章的 RSS 时间(GMT时间),在本地上显示的时间和在服务器上显示的时间不一致. 原因是时区不一致,那么在 JavaScript 中,如何将时间转换为统一 ...

  6. swift 学习(一)基础知识 (基本数据类型,操作符,流控制,集合)

    xcode 中调用API帮助 1.查看简单信息,选中后 按键 control +左键单击  或者按 右侧属性栏 里的帮助按钮 2.完整API,选中后 按键 control +左键双击 3.查看类.函数 ...

  7. 堆 poj 2010

    选n个人从c个中 花费不超过f c个人的成绩和花费 求分数中位数最大 n是奇数 显然中位数是n/2+1 ~c-n/2之间的(假如存在的话) 用大顶堆维护前n/2个小的花费 求出以这个人为中位数的花费 ...

  8. php获取checkbox复选框的内容

    php获取checkbox复选框的内容   由于checkbox属性,所有必须把checkbox复选择框的名字设置为一个如果checkbox[],php才能读取,以数据形式,否则不能正确的读取chec ...

  9. Unity 移动端触摸屏操作

    Unity 触屏操作 当将Unity游戏运行到IOS或Android设备上时,桌面系统的鼠标左键可以自动变为手机屏幕上的触屏操作,但如多点触屏等操作却是无法利用鼠标操作进行的.Unity的Input类 ...

  10. python 学习笔记7(类/对象的属性;特性,__getattr__)

    27. 属性的__dict__系统 1)对象的属性可能来自: 其类的定义,叫做类属性 继承父类的定义 该对象实例定义(初始化对象时赋值),叫做对象属性 2)对象的属性存储在对象的 __dict__ 属 ...