分布式存储 Mogilefs 部署

MogileFS是一个开源的分布式存储的解决方案,主要工作组件由三部分组成:
Tracker节点:生成映射表存储于DB,并用于接收客户端请求,通过查询数据库对客户端提供后端所存储的真实文件位置
DB节点:主要存储数据的元数据信息,可以理解为客户端来获取数据文件时提供的Key和真实存在存储里面的文件名的对照表
Storage节点:用于存储文件的节点。
工作流程,tracker收到客户端的请求,tracker通过查询DB节点,将客户端所请求的文件,对应Storage存储的位置在返回给客户端,客户端在通过拿到的文件名以及文件位置,再去Storage上查找。

实验环境:

两台centos7 其中1台配置nginx+tracker+db+storage节点,另外一台只提供Storage。

安装:

由perl语言开发,未被收录到base和epel源中,这里我们采取在cpan上安装。

yum -y install make gcc unzip perl-DBD-MySQL perl perl-CPAN perl-YAML perl-Time-HiRes

先安装这一堆玩意,以便让cpan能正确安装mogilefs

安装完成后直接执行

cpan MogileFS::Server

分布式存储 Mogilefs 部署

这里一路回车,然后知道箭头前两处,提示是否自动搜索cpan站点,一定要选no 不然得等死,第二个箭头继续n 他提示是否提供一些站点我们自行选择,也可以yes根据提示慢慢选,但是我这里no掉了,下面叫你输入cpan站点,用的163的cpan镜像站点,这样安装会比较快,然后又是一路回车

接着开始安装,可以看到他还会自动解决一些依赖关系

分布式存储 Mogilefs 部署

分布式存储 Mogilefs 部署

安装完成过后看到已经有了关于mogilefs的命令了 其中mogilefsd是tracker的启动命令,mogstored是存储节点的启动命令 mogdbsetup是为我们初始化数据库的。

然后执行

cpan MogileFS::Utils 

安装mogilefs的管理工具

接着,我们去安装数据库,并且授权一个账号可以访问,就不演示了。

分布式存储 Mogilefs 部署

使用mogdbsetup –help可以看到支持的选项

注意 这里我只简单给了两个参数,默认会使用root用户连接localhost去创建数据库,应该也会创建用户之前授权白做了,因此如果数据库单独提供,并且root有密码,按上图的参数写全即可

接着几个Y 就可以创建成功了,接着连入数据库看到给我们验证是否初始化。

分布式存储 Mogilefs 部署

接着提供一个配置文件

分布式存储 Mogilefs 部署

配置文件中提供的指令就不解释了,基本能见名之意,这里需要提一下,需要注意两点:

1、mogilefsd 不能以root用户运行,所以要su到另一个用户启动(至于具体为啥,我去找了,没找到解释的,应该还是出于安全考虑吧,把权限控制到最小,毕竟生产环境中如果能不用root用户运行的进程我们都应该不用root运行)

2、mogilefsd启动时可以用类似–daemon=1 db_user= 。。。来启动,完全可以不需要配置文件启动的,另外这里只提供了一些基本的配置指令,具体可以去https://github.com/mogilefs/MogileFS-Server/tree/master/conf  了解。

然后提供storge的配置文件 并启动服务

分布式存储 Mogilefs 部署

这里提供了一个http的访问接口为7500,7501为tracker检测后端健康状态的端口,docroot就是我们真是存放数据的位置了。

记得先提供这么一个路径,否则会启动不了,接着去配置第二台storage节点就不演示了和第一个节点一样(创建的目录名需要修改一下,在tracker是以全局看的,所有主机的存储节点应该标识唯一)

分布式存储 Mogilefs 部署

添加两个主机

分布式存储 Mogilefs 部署

添加两个主机上的设备,这里的设备你可以理解为就是数据存储的位置

分布式存储 Mogilefs 部署

出问题了,识别不了空间!!!!

分布式存储 Mogilefs 部署

可以了,这里出的问题是啥呢~ 看下面两张图就清楚了

分布式存储 Mogilefs 部署

分布式存储 Mogilefs 部署

分别是两个节点上的~ 看出来了么~~ 

一个主机我是修改了stroge配置文件,一个是我在原有目录上在此新建了一个目录。

由此可见,创建dev目录的位置 需要在docroot指的位置下才行~~~~~~~

接着我们就可以尝试上传文件了~

分布式存储 Mogilefs 部署

添加一个域 并列出域的列表。域又是什么呢,你可以理解为之前我们做的添加完设备后,在tracker主机上后,(从tracker主机上看,给了他一个很大的磁盘,它拿来后自己分了区~,可以表明每个域存放内容,比如windows上我们常用的 D盘拿来装游戏 E盘拿来装电影~~)上图的class又是啥呢,他是整个复制环节的最小复制单位,我们可以通过定义他来修改在每一个storage节点上个文件存储的份数,我们这里就不没必要设置他了。mindevcount代表存储的最小份数 2份 ,replpolicy 存储策略 多主机存储、hashtype哈希类型 没有

接着我们测试的话基本设置就完了,现在来提一下我们上面用到的命令 mogadm

分布式存储 Mogilefs 部署

使用mogadm –help 可以看到许多的子命令,并且后面会有描述,那具体每个命令怎么使用,我们就可以以下图的示例获取了

分布式存储 Mogilefs 部署

现在我们就来上传一个文件看看吧~

分布式存储 Mogilefs 部署

此次试验失败告终。 两个节点都可以上传文件,但始终都只保存一份。

在发现这个问题过后,做了如下检测

1、授权文件目录(想来应该不是这个问题 因为本来就能分开存放,只是不能复制)

2、两个节点存储目录相同

3、看进程发现replicate进程只有一个,以为一个进程只能写一个节点,事实证明错误的想法

4、修改存储份数

5、另起了一个mogilefsd进程,相同问题

6、新建域,新建class

7、时间同步

8、两节点间可以通过以mogadm host命名的域名访问

9、终极办法。。。重启。。。


问题依旧(怎么会没日志!!!!),网上资料好少,全是安装,配置的,还都是马哥提供的rpm包,不得不吐槽下。

空了准备换centos6+cpan安装,如果还有问题就尝试用马哥提供的RPM包了。

另外哪位大神遇到过这问题啊,指点一下。

原创文章,作者:N24_Ghost,如若转载,请注明出处:http://www.178linux.com/70466

(0)
N24_GhostN24_Ghost
上一篇 2017-03-04 11:41
下一篇 2017-03-05 01:06

相关推荐

  • N23-卡卡琦-第一周

    1、描述计算机的组成及其功能 硬件: 控制器:是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,根据其要求进行控制,调度程序、数据、地址,协调计算机各部分工作及内存与外设的访问等;运算器:运算器的功能是对数据进行各种算术运算和逻辑运算,即对数据进行加工处理;存储器:存储器的功能是存储程序、数据和各种信号、命令等信息,并在需要时提供这些信息;输入输…

    Linux干货 2016-11-16
  • 子网掩码快速划分-心算

    问题状况: 不管作为一名网络工程师还是一名运维工程师,快速心算划分出网络掩码是必备得技能,      为什么要进行子网掩码划分? 纯二层环境不能隔离广播 有安全 管理方面的问题 解决办法:在二层环境下增加三层设备 将原本的一个主类网络号划分成多个子网     掩码基础知识:     注意:此步没记住不要往下进行     死记硬背1:     2^0=1   …

    Linux干货 2017-03-26
  • 磁盘管理

    一、磁盘结构     设备文件         I/O Ports: I/O设备地址         一切皆文件:    &nbs…

    Linux干货 2016-09-01
  • Redis应用场景

    1.  MySql+Memcached架构的问题   实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加,和访问量的持续增长,我们遇到了很多问题:   1.MySQL需要不断进行拆库拆表,Memcached也需不断跟着扩容,扩容和维护工作占据…

    Linux干货 2016-03-22
  • 网络总结

    linux 网络配置 linux的网络服务是由内核提供。 网卡在内核看来就是个设备,各种网络配置不在网卡上。各种配置都是针相应网络管理程序使用的。 不同发行版的网络管理工具也是不一样(net-tools/iproute)。网络服务的管理程序(守护进程)也是不一样(脚本/程序)。 网络管理工具是将用户的设定直接传递给内核的网络服务,及时有效。 很多管理工具可以…

    Linux干货 2016-09-09
  • drbd+corosync+pacemaker

    存储分类: DAS:直接附加存储;例如ide,sata,scsi,sas等 NAS:网络附加存储;即文件级别共享存储;例如nfs等 SAN:存储区域网络;即块级别共享存储;例如ip-san,fc-san   共享存储选型比较: SAN性能优良,价格昂贵; NAS性能基于文件系统级别,性能低下; 因此,另一个DRBD诞生,全称为分布式复制块设备,Di…

    Linux干货 2017-11-13

评论列表(4条)

  • 马哥教育
    马哥教育 2017-03-13 23:30

    虽然文章中实验失败了,但还是给个~~最后的总结很好~有时间再来一次~~加油!

  • yhy1271927580
    yhy1271927580 2017-05-03 23:23

    为什么会出现Malformed config file (line 2) at /usr/local/share/perl5/MogileFS/Config.pm line 136, line 2. 错误,启动mogilefsd的时候就总是这样,请问碰到了这个问题吗

    • N24_Ghost
      N24_Ghost 2017-05-04 09:50

      @yhy1271927580
      看提示应该是你启动的时候配置文件指的是这个文件,但是这个文件的 136和第二行有错误。

    • yhy1271927580
      yhy1271927580 2017-05-04 14:08

      @N24_Ghost遇到了跟你一样的问题,我检查了目录权限,mogs用户可以写入数据,请求你的这个问题解决了吗