zoukankan      html  css  js  c++  java
  • fastdfs的入门到精通(fastdht环境的搭建)

    引言:

      在前面几篇博客介绍中,我们已经了解到fastdfs单机搭建和关于http请求访问的fastdfs+nginx的实现。现在还存在的问题,当我们上传同一个文件时,没有给我们去重,依然上传成功,返回了一个上传标识。这种情况是我们不想看到的,所以,怎么实现文件的去重,作者余庆给我们提供了一种新的技术,fastdht

    介绍:

      FastDHT是一个基于键值对(Key Value Pair)的高效的分布式Hash系统,她可以用来存储大量的Key Value Pair,比如可以用来存储文件名映射表、session数据、用户相关数据等等。 
      FastDHT服务器端底层存储采用Berkeley DB,支持大数据量;网络IO采用libevent,支持大并发连接。FastDHT只用到了BDB最基本的存储功能,数据同步是自己实现的,采用了binlog的复制方式

      由客户端决定应该选择哪台服务器,为例避免查表,应该根据key的hash code来选择服务器,算法描述如下: 
         1. 计算出key的hash值(hash_code) 
         2. group_index = hash_code % group_count 
            3. new_hash_code = hash_code高16位和低16位互换 
         4. server_index = new_hash_code % 组内server_count 
      计算server_index和group_index时使用了不同的hash code,是因为如果group_count和组内server_count相等,例如都等于2,那么对于一个组来说,任何key值都将选中其中一台固定的服务器(server_index == group_index)。 

      FastDHT中,key由三部分组成:namespace、object ID和key name。这个设计和数据库的层级划分相似:namespace对应database,object Id对应table,而key对应字段。引入namespace的目的是解决多个使用者(如:应用或产品)之间可能存在的数据冲突问题;引入object Id是便于对object相关的数据(如用户资料)进行组织和管理,以提高整体性能。引入namespace和object ID使得系统具有更大的灵活性,在实际使用中,这两个字段可以设置为空值。在计算key的hash code时,如果namespace和object ID不为空,将这二者合并起来作为hash函数的输入;否则将key作为hash函数的输入。 

      系统扩容时,为了避免重新进行hash分布(rehash),FastDHT引入了逻辑分组的概念。一个物理分组对应一组服务器,一组服务器(物理分组)上可以有多个逻辑分组。FastDHT的一个服务进程支持多个逻辑分组,每个组对应一个BDB的数据文件。这样的设计为以后的扩容提供了便利。在初期估算出今后需要的大致分组数目(逻辑分组数),然后将逻辑分组对应到物理分组中。扩容时,将一个或多个逻辑分组迁移到新增的物理分组上,只需要拷贝对应的BDB数据文件,并修改相应的配置文件,重启服务器端和客户端程序即可。 

      FastDHT支持超时(timeout),每个key都有超时属性。这样可以使用FastDHT来存储session数据,比传统的数据库存储方案更加高效和简洁。 

    原理: 

      

    安装:

      1.下载fastdht和db-18.1.32.tar.gz

        db-18.1.32.tar.gz

        fastdht-master.zip

        

       2.上传/root/fastdfs/  并解压

        

       3. 安装BerkeleyDB   

       在步骤2后。
            cd /db-18.1.32
            cd build_unix/
            ./../dist/configure
            make && make install

      4. 安装fastdht

      cd fastdfs/fastdht-master/
       ./make.sh && ./make.sh install

       5. 修改fastdht的配置文件

        mkdir /data/fastdht     --创建一个文件夹,用来保存fastdht的日志文件
        cd /etc/fdht/      -- 切换到fdht配置文件  vi fastd.conf      -- 编辑配置文件 base_path
    =/data/fastdht -- 修改成上面创建的文件夹 vi fdht_servers.conf -- 在修改fdht_severs.conf 将来配置fdht集群的,后续详细介绍。本节只搭建环境 group_count = 1   -- 修改成1   group0 = 192.168.236.130:11411 --修改本节fdht服务器主机地址

      6.修改storage.conf

       check_file_duplicate=1            -- 修改成1 检测是否已经上传,如果已上传就生成一个链接指向该文件,没有,就上传 
         keep_alive=1                 -- 修改成1  意思是保持长连接
         #include /etc/fdht/fdht_servers.conf    --指定配置文件   注意。#必须加

      7.启动服务:

      /usr/local/bin/fdhtd /etc/fdht/fdht    -- 启动fdht 服务
      fdfs_trackerd /etc/fdfs/tracker.conf restart --重启tracker服务
      fdfs_storaged /etc/fdfs/storage.conf restart --重启storage服务

      查询服务启动是否完成:

      

      到这,fdht和fastdfs就集成完了,大家注意上面搭建细节

      8.测试: 

      我连续上传同一个文件两次,效果如下:可看到两次返回的标识是不一样的,那实际文件保存情况呢。 

     


    有兴趣的可以搭建一下,这样印象才会深一点

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    二分图那套理论
    洛谷P4351 [CERC2015]Frightful Formula【组合计数】
    「AGC023E」Inversions【组合计数】
    类欧几里得算法及其拓展
    OLAP 一些扯淡
    auto vectorized case shift
    备忘录
    lambda function pointer
    C++ atomic
    gdb 使用了 O0 但是还是有 <optimized out>
  • 原文地址:https://www.cnblogs.com/huhongy/p/12526530.html
Copyright © 2011-2022 走看看