++++++++++++++构建MFS分布式文件系统++++++++++++++
PB级别:
企业存储空间达到PB级别,即100万GB空间。(1PB=1000TB,1TB=1000GB,1GB=1000MB)
MFS原理:
MFS是一个具有容错额网络分布式文件系统,他把数据分散存放在多个物理服务器上,而呈现给用户则是一个统一的资源。
MFS组成:
1)元数据服务器:
2)元数据日志服务器:
3)数据存储服务器:
4)客户端:
MFS拓扑:
-------Client---------Master---------MataLogger---------Chunk1---------Chunk1---------Chunk1---------
192.168.1.1 192.168.1.10 192.168.1.100 192.168.1.201 192.168.1.202 192.168.1.203
配置步骤:
一、Master
[root@localhost ~]# yum -y install zlib-devel
[root@localhost ~]# useradd mfs -s /sbin/nologin -u 98
[root@localhost ~]# tar -zxvf mfs-1.6.27-5.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/mfs-1.6.27/
[root@localhost mfs-1.6.27]# ./configure --prefix=/usr/local/mfs --with-default-user=mfs --with-default-group=mfs --
disable-mfschunkserver --disable-mfsmount
[root@localhost mfs-1.6.27]# make && make install
[root@localhost ~]# cd /usr/local/mfs/etc/mfs/
[root@localhost mfs]# cp mfsmaster.cfg.dist mfsmaster.cfg
[root@localhost mfs]# cp mfsexports.cfg.dist mfsexports.cfg
[root@localhost mfs]# cp mfstopology.cfg.dist mfstopology.cfg
[root@localhost mfs]# cd /usr/local/mfs/var/mfs/
[root@localhost mfs]# cp metadata.mfs.empty metadata.mfs
[root@localhost ~]# vim /usr/local/mfs/etc/mfs/mfsmaster.cfg
不做任何改动
[root@localhost ~]# vim /usr/local/mfs/etc/mfs/mfsexports.cfg
不做任何改动
[root@localhost ~]# /usr/local/mfs/sbin/mfsmaster restart //启动mfs
[root@localhost ~]# ps -elf | grep mfs
[root@localhost ~]# netstat -anpt | grep mfs
[root@localhost ~]# /usr/local/mfs/sbin/mfsmaster stop //停止mfs
二、MataLogger
[root@localhost ~]# yum -y install zlib-devel
[root@localhost ~]# useradd mfs -s /sbin/nologin -u 98
[root@localhost ~]# tar -zxvf mfs-1.6.27-5.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/mfs-1.6.27/
[root@localhost mfs-1.6.27]# ./configure --prefix=/usr/local/mfs --with-default-user=mfs --with-default-group=mfs --
disable-mfschunkserver --disable-mfsmount
[root@localhost mfs-1.6.27]# make && make install
[root@localhost ~]# cd /usr/local/mfs/etc/mfs/
[root@localhost ~]# cp mfsmetalogger.cfg.dist mfsmetalogger.cfg
[root@localhost ~]# vim /usr/local/mfs/etc/mfs/mfsmetalogger.cfg
修改:
MASTER_HOST = 192.168.1.10
[root@localhost ~]# /usr/local/mfs/sbin/mfsmetalogger restart //启动
[root@localhost ~]# ps -elf | grep mfs
[root@localhost ~]# netstat -anpt | grep mfs
[root@localhost ~]# /usr/local/mfs/sbin/mfsmetalogger stop //停止
三、Chunk
[root@localhost ~]# yum -y install zlib-devel
[root@localhost ~]# useradd mfs -s /sbin/nologin -u 98
[root@localhost ~]# tar -zxvf mfs-1.6.27-5.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/mfs-1.6.27/
[root@localhost mfs-1.6.27]# ./configure --prefix=/usr/local/mfs --with-default-user=mfs --with-default-group=mfs --
disable-mfsmaster --disable-mfsmount
[root@localhost mfs-1.6.27]# make && make install
[root@localhost ~]# cd /usr/local/mfs/etc/mfs/
[root@localhost mfs]# cp mfschunkserver.cfg.dist mfschunkserver.cfg
[root@localhost mfs]# cp mfshdd.cfg.dist mfshdd.cfg
[root@localhost ~]# vim /usr/local/mfs/etc/mfs/mfschunkserver.cfg
添加:
MASTER_HOST = 192.168.1.10
[root@localhost ~]# vim /usr/local/mfs/etc/mfs/mfshdd.cfg
添加:
/data
[root@localhost ~]# mkdir /data
[root@localhost ~]# chown -R mfs:mfs /data/
[root@localhost ~]# /usr/local/mfs/sbin/mfschunkserver restart
[root@localhost ~]# ps -elf | grep mfs
[root@localhost ~]# netstat -anpt | grep mfs
四、Client
1、安装fuse
[root@localhost ~]# yum -y install zlib-devel
[root@localhost ~]# tar -zxvf fuse-2.9.2.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/fuse-2.9.2/
[root@localhost fuse-2.9.2]# ./configure && make && make install
[root@localhost fuse-2.9.2]# vim /etc/profile
添加:
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH
[root@localhost fuse-2.9.2]# . /etc/profile //立即生效
[root@localhost fuse-2.9.2]# source /etc/profile //重启生效
2、安装
[root@localhost ~]# useradd mfs -s /sbin/nologin -u 98
[root@localhost ~]# tar -zxvf mfs-1.6.27-5.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/mfs-1.6.27/
[root@localhost mfs-1.6.27]# ./configure --prefix=/usr/local/mfs --with-default-user=mfs --with-default-group=mfs --
disable-mfsmaster --disable-mfschunkserver --enable-mfsmount
如果还是有问题的,解决方法:yum -y install fuse-devel
[root@localhost mfs-1.6.27]# make && make install
[root@localhost ~]# modprobe fuse
[root@localhost ~]# mkdir /xixi
[root@localhost ~]# /usr/local/mfs/bin/mfsmount /xixi -H 192.168.1.10
[root@localhost ~]# mount
[root@localhost ~]# df -hT
[root@localhost ~]# umount /xixi //直接卸载就可以了
[root@localhost ~]# vim /etc/profile
添加:
export PATH=/usr/locla/mfs/bin:$PATH
[root@localhost ~]# source /etc/profile
或者
[root@localhost ~]# ln -s /usr/local/mfs/bin/* /usr/local/bin/
验证:
[root@localhost ~]# mfsgetgoal -r /xixi
[root@localhost ~]# mfssetgoal -r 3 /xixi
注意:生产环境Chunk Server节点数应至少大于2,文件的副本数应小于小于等于Chunk Server服务器数
[root@localhost ~]# touch /data/mfs/hehe
[root@localhost ~]# mfsgetgoal /data/mfs/hehe
MFS监控:
1)Master中:
[root@localhost ~]# /usr/local/mfs/sbin/mfscgiserv restart
2)Client中:
[root@localhost ~]# firefox http://192.168.1.10:9425 &
MFS的维护和灾难恢复
1)MFS集群的启动顺序
1启动mfsmaster进程
2启动所有mfschunkserver进程
3启动mfsmetalogger进程
4在所有客户端挂载MFS文件系统
2)MFS集群的停止顺序
1再所有客户端卸载MFS文件系统
2用mfschunkserver -s 命令停止mfschunkserver进程
3用mfsmetalogger -s 命令停止mfsmetalogger进程
4用mfsmaster -s 命令停止 mfsmaster进程
3)MFS灾难恢复
1元数据主文件metadata.mfs ,运行时命名为metadata.mfs.back
2元数据改变日志changelog*.mfs
master故障时,可以从metalogger 中回复master:
1安装一台mfsmaster,利用同样的配置来配置mfsmaster。
2将metalogger上/usr/local/mfs/var/mfs 目录下的文件复制到mfsmaster相应的目录中。
3利用mfsmetarestore命令合并数据changelogs
/usr/local/mfs/sbin/mfsmetarestore -m metadata_m1.mfs.back -o metadata.mfschangelog_m1.*.mfs
注意:恢复后的master需要重新挂载客户端。
1. 准备条件
2. 现在安装包 mfs-1.6.15.tar.gz
3. #groupadd mfs
4. #useradd -g mfs mfs
5. #cd /root
6. #tar -zxvf mfs-1.6.15.tar.gz
7. #cd mfs-1.6.15
8. #./configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var/lib --with-default-user=mfs --with-defaultgroup=
mfs --disable-mfsmaster
9. #make
10. #make install
11. #准备chunk server 服务所需的配置文件:
12. #cd /etc/
13. #cp mfschunkserver.cfg.dist mfschunkserver.cfg
14. #cp mfshdd.cfg.dist mfshdd.cfg
15. #在mfshdd.cfg 加入下面的文本行你需要挂在的文件目录
16. /data/slot0
17. /data/slot1
18. /data/slot2
19. /data/slot3
20. /data/slot4
21. [root@cdn etc]# chown -R mfs:mfs /data/slot0
22. [root@cdn etc]# chown -R mfs:mfs /data/slot1
23. [root@cdn etc]# chown -R mfs:mfs /data/slot2
24. [root@cdn etc]# chown -R mfs:mfs /data/slot3
25. [root@cdn etc]# chown -R mfs:mfs /data/slot4
26. echo '10.200.93.71 mfsmaster' >> /etc/hosts
27. #请到chunksever 服务
28. #/usr/sbin/mfschunkserver start

构建MFS分布式文件系统的更多相关文章

  1. 构建Mogilefs分布式文件系统(配置篇)

    构建Mogilefs分布式文件系统:  当下互联网飞速发展,海量并发所产生的数据量以几何方式增长,随着信息链接方式日益多样化,数据存储的结构也发生了变化,在这样的压力下我们不得不重新审视大量数据的存储 ...

  2. MFS分布式文件系统

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

  3. MFS分布式文件系统【1】概述

    注:以下内容来自互联网 MFS文件系统概论 MFS是linux下的开源存储系统,是由波兰人开发的.MFS文件系统能够实现RAID的功能,不但能够节约存储成本,而且不逊于专业的存储系统,能够实现在线扩展 ...

  4. mfs分布式文件系统,分布式存储,高可用(pacemaker+corosync+pcs),磁盘共享(iscsi),fence解决脑裂问题

    一.MFS概述 MooseFS是一个分布式存储的框架,其具有如下特性:(1)通用文件系统,不需要修改上层应用就可以使用(那些需要专门api的dfs很麻烦!).(2)可以在线扩容,体系架构可伸缩性极强. ...

  5. MFS分布式文件系统【4】客户端的挂载MFS存储空间

    挂载基于MooseFS 分布式文件,客户端主机必须安装FUSE软件包(FUSE版本号至少2.6,推荐版本号大于2.7的fuse) [root@master ~]# rpm -qa|grep fuse ...

  6. MFS分布式文件系统【3】存储节点 CHUNK SERVER 部署

    [root@ky_hs_252 mfs-1.6.27]# mkdir /usr/local/mfs [root@ky_hs_252 mfs-1.6.27]# useradd mfs -s /sbin/ ...

  7. MFS分布式文件系统【2】MFS MASTER 部署

    MFS版本 mfs-1.6.27 MFS-MASTER 192.168.1.190 MFS-CHUNKSERVER1 192.168.1.252 MFS-CHUNKSERVER2 192.168.1. ...

  8. 分布式文件系统之MogileFS工作原理及实现过程

    MogileFS是一套高效的文件自动备份组件,由Six Apart开发,广泛应用在包括LiveJournal等web2.0站点上.MogileFS由3个部分组成:   第1个部分:是server端,包 ...

  9. 大数据 --> 分布式文件系统HDFS的工作原理

    分布式文件系统HDFS的工作原理 Hadoop分布式文件系统(HDFS)是一种被设计成适合运行在通用硬件上的分布式文件系统.HDFS是一个高度容错性的系统,适合部署在廉价的机器上.它能提供高吞吐量的数 ...

随机推荐

  1. JEECG & JEESite Tomcat集群 Session共享

    多台tomcat服务的session共享 memcached与redis - JEECG开源社区 - CSDN博客https://blog.csdn.net/zhangdaiscott/article ...

  2. C#封装SQLite数据库

    网上有许多介绍关于SQLite数据库的,这里我就不多说了,这里主要介绍SQLite数据库在C#中的应用,它的应用主要依赖于System.Data.SQLite.dll文件,可以点击这里下载https: ...

  3. mybatis出现NoSuchMethodException异常

    今天在idea中调试项目(ssm搭建的项目)的时候,mybatis突然出现了NoSuchMethodException异常,具体的异常时: java.lang.NoSuchMethodExceptio ...

  4. js关闭当前页

    /*关闭当前页*/ function closeCurrentPage() { var userAgent = navigator.userAgent; if (userAgent.indexOf(& ...

  5. django之路由层

    一 Django中路由的作用 二 简单的路由配置 三 有名分组 四 路由分发 五 反向解析 六 名称空间 七 django2.0版的path 一 Django中路由的作用 URL配置(URLconf) ...

  6. Plugin/Preset files are not allowed to export objects,webpack报错/babel报错的解决方法

    1.为什么会报错 ? 这里抱着错误是因为 babel 的版本冲突. 多是因为你的 babel 依赖包不兼容. 可以查看你的 package.json 的依赖列表 即有 babel 7.0 版本的( @ ...

  7. swagger bug

    https://blog.csdn.net/u011943534/article/details/81778125 处理swagger报错Could not resolve pointer: /def ...

  8. Delphi (Library Path Browsing Path)

    首先要明白的一个概念是dcu文件 *.dcu是*.pas的编译后单元文件(Delphi Compiled Unit), 编译器把它和库文件连接起来就构成了可执行文件*.exe 或*.dll等,相当于C ...

  9. Windows 访问 CentOS 7 共享文件夹 Samba 配置

    Windows 使用用户名.密码访问 CentOS 7 共享文件夹 执行命令,查看 Windows 工作组:net config workstation 执行命令,安装 Samba:yum insta ...

  10. Nginx 热部署最版本

    L10 进入nginx里的sbin目录 拷贝原先的做备份 cp nginx nginx.old 然后将已经编译好的nginx二进制文件复制到sbin目录下并覆盖原有的二进制文件 kill -USR2 ...