热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mogifs分布式文件系统

分布式文件系统:1:系统的各个组件分布于网络上的多个计算机上2:各组件彼此之间仅仅通过消息传递来通信并协调运行分布式文件系统存在的意义:A:向上扩展的性价比越来越低;单机扩展存在性

分布式文件系统:

    1:系统的各个组件分布于网络上的多个计算机上

    2:各组件彼此之间仅仅通过消息传递来通信并协调运行

分布式文件系统存在的意义:

    A:  向上扩展的性价比越来越低;单机扩展存在性能的临界点

    B: 出稳定性及可用性考虑,单机会存在多方面的问题

   CPU   内存   IO:性能

网络IO

   多进程;每个进程响应一个请求  

   多进程;每个进程生成多个进程,每个进程响应一个请求 

   多线程:每个线程响应多个请求

基于socket实现网络通信开发,实现方式

   BIOBlocaing IO:阻塞io

     一个进程或者一个线程处理一个请求,

   NIONonblocking IO

     基于事件驱动(epll)思想,采用Reactor模式

AIO:基于事件驱动(epll)思想,采用Proactor模式

如何把应用从单机扩展为多机

   输入设备的变化

变得多了

输出设备的变化

分布式系统实现的难点

   缺乏全局时钟

   面对故障时的独立性

   处理单点故障

   事务处理麻烦:ACID

             2pc BASE CAP Paxos

大型网站站点的架构演进方式:

      LAMT  LNMT

应用从资源占用的角度分类:

       CPU boundcpu 密集型

       IO boundIO密集型

引用mysql主从面临的问题:

      数据复制的问题

      应用选择数据源的问题

引用缓存

         页面缓存:varnish squid       

           数据缓存:key-valuememcached

主库写数据操作压力:数据库拆分

         垂直拆分:把数据库中不同的业务的数据拆分到不同的数据库中          

             难点 :单机的ACID保证被打破:要么放弃事务,要么引入分布式事务,

一些join查询操作将变得非常困难:

 原来依赖于外键实现的约束将无法保证

          水平拆分:把一个单独表中的数据拆分到多个不同的数据服务器上

                难点:单机的ACID保证被打破,一些join查询操作将变得非常困难,原来依赖于外键实现的约束将无法保证,自增序列号的ID的产生会有影响,针对单张表的查询可能要垮库操作,

 Nosql:非关系型数据库

      文档数据库

       列式数据库

  DFS:非结构化数据

       TfsMogileFS:适用于海量的小文件

HDFSGFS:少量文件

分布式的事务的实现:

      事务:事物的参与者,支持事务的服务器,资源服务器,事务管理器

   ,       

 2PC:两段式提交协议:就是当一个事务发出请求和响应请求是同步的

,


  Paxos:比2PC更加轻量级:不存在拜占庭将军问题,通讯网络不安全,无法完成可靠的消息传输

要同时OKcommit,当上面的请求有一个出错时,就无法commit

   CAP:一致性,可用性,网络分区容错性

只能同时满足三者中的两者,因此,分布式系统的目标:AP(大多数分布式系统都选择此项)   CA(无法实现分布式)  CP(用的少,代价大)

分布式的目标:加强AP,在C上进行妥协:

       满足BASE模型:基本可用性



同时大数据给我们带来的挑战:

 数据采集,数据的存储,数据的搜索,数据的共享,数据的传输,数据的分析,数据的可视化都难以实现

,





挂载到一个目录就可以使用le

       Tracker:mogilefsd进程,实现的功能:文件的复制{replication} 删除(deletion  query 监控(monitor

         Mysql节点:用于Tracker存储元数据:mogilefs的名称空间及文件名,实际是一个httpd服务

       Storagenodesmogstored进程,文件实际存储位置

     Mogildfs:W  R N   W+R弱一致性

实现:三个节点:分别是172.16.249.97  172.16.249.85  172.16.249.165

172.16.249.85tracker服务器mysql服务器

   Lftp172.16.0.1/pub/Sources/6.x86_64下下载mogilefs

Yum 安装如下包: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

perl-Net-Netmask-1.9015-8.el6.noarch.rpm

perl-Perlbal-1.78-1.el6.noarch.rpm

MogileFS-Utils-2.19-1.el6.noarch.rpm

perl-MogileFS-Client-1.14-1.el6.noarch.rpm

yum install y mysql-server

授权数据库用户,并初始化mysql

MariaDB [(none)]> grant all on mogdb.* to‘moguser‘@‘172.16.%.%‘ identified by ‘mogpass‘;

 MariaDB[(none)]> flush privileges;

然后连接[root@www mogilefs]# mogdbsetup --dbname=mogdb --dbuser=moguser--dbhost=172.16.249.85 --dbpass=mogpass

会发现出现错误:大概意思需要一个root的远程连接

 MariaDB[(none)]> grant all on *.* to ‘root‘@‘172.16.%.%‘ identified by ‘han‘;

Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> flush privileges;

Query OK, 0 rows affected (0.00 sec)

再次连接:[root@www mogilefs]# mogdbsetup --dbname=mogdb --dbuser=moguser--dbhost=172.16.249.85 --dbpass=mogpass --dbrootuser=root --dbrootpass=han

 出现如下错误:

Failed to connect to DBI:mysql:mysql;host=172.16.249.85;port=3306 asspecified root user (root): Access denied for user ‘root‘@‘www.http3.com‘(using password: NO)

解决:MariaDB [(none)]> grant all on *.* to ‘root‘@‘www.han3.com‘ identifiedby ‘han‘;

Query OK, 0 rows affected (0.00 sec)

 

MariaDB [(none)]> flush privileges;

Query OK, 0 rows affected (0.00 sec)

在次连接[root@www mogilefs]# mogdbsetup --dbname=mogdb --dbuser=moguser--dbhost=172.16.249.85 --dbpass=mogpass --dbrootuser=root --dbrootpass=han

就会成功了

 修改配置文件:

  [root@www mogilefs]# vimmogilefsd.conf

db_dsn = DBI:mysql:mogdb:host=172.16.249.85

db_user = moguser

db_pass = mogpass

listen = 172.16.249.85:7001

启用:root@www mogilefs]# service mogilefsd restart

如果出现错误:使用mogilefsd –-help查看

172.16.249.97mogstored节点

 172.16.249.165mogstored节点

scp  -r mogilefs/172.16.249.165:/root/

scp  -r mogilefs/ 172.16.249.97:/root/

分别安装

Yum 安装如下包: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

perl-Net-Netmask-1.9015-8.el6.noarch.rpm

perl-Perlbal-1.78-1.el6.noarch.rpm

perl-IO-AIO

编辑配置文件

[root@www mogilefs]# vim /etc/mogilefs/mogstored.conf

docroot = /mogdata/data

mkdir pv /mogdata/data

chown R mogilefs.mogilefs /mogdata

启动mogstored:(750l

[root@www mogilefs]# service mogstored start

 会出现好多命令mog双击tab键盘:

我们查看当前的mogstored节点

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host list

 加入一个mogstored节点

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host add node2(自己去的) --ip 172.16.249.97 --status=alive

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host add node3 --ip=172.16.249.165--status=alive

我们可以使用mogadm help查看语法

  使用mark时可以把各个节点下线

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host mark node3 down(下线)

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host list

node2 [1]: alive

  IP:       172.16.249.97:7500

 

node3 [2]: down

  IP:       172.16.249.165:7500

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 host mark node3 alive(上线)

添加主机上的设备:device

  [root@www mogilefs]# mogadm  --trackers=172.16.249.85:7001 device list(列出设备)

node2 [1]: alive

                    used(G)    free(G)  total(G)  weight(%)

 

node3 [2]: alive

                    used(G)    free(G)  total(G)  weight(%)

添加设备:[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 device add node2 dev1

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 device add node3 dev2

[root@www mogilefs]# mogadm --trackers=172.16.249.85:7001 device list

   node2 [1]: alive

                    used(G)    free(G)  total(G)  weight(%)

   dev1:   alive     0.000      0.000      0.000        100

 

node3 [2]: alive

                    used(G)    free(G)  total(G)  weight(%)

   dev2:   alive     0.000      0.000      0.000        100

查看整体摘要信息

   [root@www mogilefs]# mogadm  --trackers=172.16.249.85:7001 device summary

Hostname        HostID  Status  used(G)  free(G) total(G)    %Used

node2           [   1]: alive     0.000    0.000   0.000

node3           [  2]:  alive     0.000   0.000    0.000

添加一个domain(名称空间)domain内部可以有一个class代表一个dirtory

 查看domain

 [root@www mogilefs]# mogadm  --trackers=172.16.249.85:7001 domain list

 domain               class                mindevcount   replpolicy  hashtype

-------------------- -------------------- -------------

添加一个域:

   [root@wwwmogilefs]#mogadm --trackers=172.16.249.85:7001domain add files

 我们要在响应的、/mogdata/data下建立相应的devn并且把其属主属组该我mogilefs这样就可以使用了在上传文件就好了

上传数据:

[root@www ~]# mogupload --trackers=172.16.249.85:7001 --domain=files--key=‘/fstab.html‘ --file=‘/etc/fstab‘

查看数据:

  [root@www ~]# clear

[root@www ~]# mogfileinfo --trackers=172.16.249.85:7001 --domain=files--key=‘/fstab.html‘

- file: /fstab.html

     class:              default

  devcount:                    1

    domain:                files

       fid:                    6

       key:          /fstab.html

    length:                  921

 - http://172.16.249.165:7500/dev2/0/000/000/0000000006.fid

我们也可以在浏览器上输入http://172.16.249.165:7500/dev2/0/000/000/0000000006.fid查看

[root@www ~]# mogadm --trackers=172.16.249.85:7001 domain add images也可以上传一个图片与其上 

  MogilefsW写节点 R读节点 N所有节点:


本文出自 “正则表达式和fgrep” 博客,请务必保留此出处http://9025736.blog.51cto.com/9015736/1561184

mogifs分布式文件系统


推荐阅读
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
author-avatar
Mr_JJwonG05
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有