zoukankan      html  css  js  c++  java
  • redisfs – Redis+FUSE 构建的文件系统(转)

    Redis 是高效的内存数据库,FUSE 是Linux内核的一个模块,利用它可以用自定义的底层存储创建自己的文件系统(如之前提到过的MongoDB 的 gridfs-fuse)。本文要介绍的是一个甚至Redis存储系统的文件系统实现:redisfs

    使用方法

    安装好redisfs后运行下面命令,指定Redis服务器的host和port,指定挂载目录,即可在此目录下挂载一个以Redis作为存储支持的文件系统

    redisfs --host=localhost --port=6379 --mount=/mnt/redis  [--read-only] [--debug] [--prefix=skx]

    同步机制

    redisfs 选择redis的主要原因是想利用redis的高性能及其同步机制,作者提供了两种方法用于构建两个同步的文件系统:

    1.使用redisfs将两个不同机器上的不同目录mount到同一个redis

    2.上面一种方式可能导致至少一个文件系统与Redis不在同一台机器上,从而导致不必要的网络开销。下图的方式是在不同的机器上,设置主从两台Redis,再直接用redisfs 去 mount 本机的Redis,数据同步通过Redis自己的同步机制去做,但这样做的代价是在Slave对应的机器上的文件系统就变成只读的了。

    快照功能

    redisfs 提供一个对文件系统做快照的功能,快照功能的实现非常简单,只需要将当前Redis中存储的所有key(相当于文件名)扫描一次,并且复制到新到key上面即可。如下:

    $ redisfs-snapsot --from=skx --to=copy

    上面操作就是把所有skx开头的key复制到一份为copy开头的key,下面再使用mount参数就可以用这个快照构建一个新的文件系统了,操作如下:

    # mkdir /tmp/safe
    # redisfs --prefix=copy --mount=/tmp/safe

    具体安装使用方式请参见官方页面:http://www.steve.org.uk/Software/redisfs/

  • 相关阅读:
    勿忘心安
    设△ABC的内角A,B,C,所对的边分别为a,b,c,且acosB-bcosA=3/5c,则tan(A-B)的最大值为
    P1011 车站
    第一天
    P1134 阶乘问题
    P3152 正整数序列
    某数论
    DO YOU WANNA BUILD A SNOW MAN ?
    luogu P1579 哥德巴赫猜想(升级版)
    紫书 习题 10-25 UVa 1575 (有重复元素的全排列+暴搜)
  • 原文地址:https://www.cnblogs.com/qq78292959/p/2901657.html
Copyright © 2011-2022 走看看