mogilefs的简单安装配置和使用


安装此软件需要 使用 CPAN 或者 源码编译 或者 自己制作rpm包

此时我们使用已经制作好的rpm包 演示


环境介绍
tracker + mysql  10.1.249.125
storage 10.1.252.52


所需要的rpm包

MogileFS-Server-2.46-2.el6.noarch.rpm            
MogileFS-Server-mogilefsd-2.46-2.el6.noarch.rpm  
MogileFS-Server-mogstored-2.46-2.el6.noarch.rpm  
MogileFS-Utils-2.19-1.el6.noarch.rpm             
perl-Net-Netmask-1.9015-8.el6.noarch.rpm
perl-Perlbal-1.78-1.el6.noarch.rpm
perl-MogileFS-Client-1.14-1.el6.noarch.rpm
perl-IO-stringy-2.110-1.2.el6.rfx.noarch.rpm
perl-Danga-Socket-1.61-1.el6.rf.noarch.rpm


安装rpm包,(所有节点都需要安装)

# yum -y install *   --> 存在依赖关系,所有上述包都需要安装



一、配置tracker节点

1.数据库设置,在tracker节点上设置

# mogdbsetup --dbhost=localhost --dbport=3306 --dbname=mogilefs \
  > --dbrootuser=root --dbrootpass=root --dbuser=moguser --dbpass=mogpass  
--> 数据库及其用户可以事先不存在,会自动设置


2.此时,我们可以到数据库中进行验证

mysql> show databases;   --> mogilefs库依然存在
+--------------------+
| Database           |
+--------------------+
| information_schema |
| jchome             |
| mogilefs           |
| mysql              |
| shopxx             |
| test               |
| testdb             |
+--------------------+

mysql> use mogilefs
mysql> show tables;  --> 生成了许多表


3.修改配置文件

# vim /etc/mogilefs/mogilefsd.conf  --> 和数据库配置要一致

db_dsn = DBI:mysql:mogilefs:host=127.0.0.1
db_user = moguser
db_pass = mogpass
listen = 10.1.249.125:7001


4.开启服务

# service mogilefsd start  --> 开启mogilefsd进程

# ss -tln | grep "7001" --> 查看是否监听7001端口


二、配置mogstored节点

1.安装同样的rpm包

2.查看配置文件 --> 使用默认即可,不需要修改

3.创建对应的目录 --> 根据配置文件中定义的

# mkdir -pv /var/mogdata
# chown -R  mogilefs.mogilefs /var/mogdata/


4.启动服务进程

# service mogstored start
# netstat -tlnp | grep "mogstored"


简单测试(以下命令在tracker节点执行)


1.检测tracker节点

# mogadm --tracker=10.1.249.125:7001 check
Checking trackers...
  10.1.249.125:7001 ... OK   --> tracker节点配置成功

  Checking hosts...       --> 此时还没有主机加入到tracker节点中
No devices found on tracker(s).


2.列出主机

# mogadm --tracker=10.1.249.125:7001 host list --> 此时为空,因为我们还没有做任何的配置



3.添加mogstored节点,接受tracker管理

# mogadm --tracker=10.1.249.125:7001 host add 10.1.252.53 --ip=10.1.252.53 --status=alive

# mogadm --tracker=10.1.249.125:7001 host list
10.1.252.53 [1]: alive
  IP:       10.1.252.53:7500  --> 添加成功


4.添加设备

# mogadm --tracker=10.1.249.125:7001 device list

10.1.252.53 [1]: alive
                    used(G)    free(G)   total(G)  weight(%)  --> 此时没有任何设置

# mogadm --tracker=10.1.249.125:7001 device add 10.1.252.53 1  --> 添加设备

# mogadm --tracker=10.1.249.125:7001 device list
10.1.252.53 [1]: alive
                    used(G)    free(G)   total(G)  weight(%)
   dev1:   alive      6.182     84.933     91.114        100   --> 添加成功


此时我们在mogstored节点的数据目录下查看,会出现 dev1目录

# ls /var/mogdata/dev1/  --> 该命令在mogstored节点执行
0  test-write  usage



5.添加域

# mogadm --tracker=10.1.249.125:7001 domain add img(域名)

# mogadm --tracker=10.1.249.125:7001 domain list
 domain               class                mindevcount   replpolicy   hashtype
-------------------- -------------------- ------------- ------------ -------
 img                  default                   2        MultipleHosts() NONE


6.

a)上传文件
# mogupload --trackers=10.1.249.125:7001 --domain=img --key="fstab" --file='/etc/fstab'

b)查看上传的文件
# moglistkeys --trackers=10.1.249.125:7001 --domain=img

c)查看访问路径
# mogfileinfo --trackers=10.1.249.125:7001 --domain=img --key='fstab'
 - http://10.1.252.53:7500/dev1/0/000/000/0000000003.fid  
 
 --> 由于我们此处只有一个mogstored节点,所有访问路径只有一个,如果我们有2个mogstored节点
 --> 则会有两个访问路径,mogilefs会自动进行文件的复制(冗余)



7.

a)首先查看文件列表
# moglistkeys --trackers=10.1.249.125:7001 --domain=img
fstab
issue

b)下载文件
# mogfetch --trackers=10.1.249.125:7001 --domain='img' --key='issue'(需要和上面对应) --file='issue.bak'(下载下来的文件名字,在当前目录下)



8.

a)首先查看文件列表# moglistkeys --trackers=10.1.249.125:7001 --domain=img
fstab
issue

b)删除文件# mogdelete --trackers=10.1.249.125:7001 --domain=img --key=fstab

c)再次查看文件列表moglistkeys --trackers=10.1.249.125:7001 --domain=img
issue  --> fstab文件已成功被删除