Memcache 文件系统MemcacheFS

memcachefs是基于FUSE的memcached文件系统,将memcache服务挂载到本地。允许查看缓存中的数据,就好像是磁盘上的文件。memcache的操作都将转换成针对普通文件般的操作。
项目地址: http://memcachefs.sourceforge.net/
一、依赖
1.FUSE 2.5 or later
2.libmemcache 1.4 or later
二、使用场景
基于本地磁盘缓存文件都可以用memcachefs来实现,效率上比磁盘更强大。比如session文件等等。如果先前的session信息就存在本地磁盘上,可以直接将memcache挂载到当前session目录上,无需更改程序,完美解决。
三、安装挂载
1.安装依赖(使用root安装)

fuse:yum -y install fuse* 
libmemcache-dev:
wget http://people.freebsd.org/~seanc/libmemcache/libmemcache-1.4.0.rc2.tar.bz2
tar -xvf libmemcache-1.4.0.rc2.tar.bz2
cd libmemcache-1.4.0.rc2
./configure
make
make install
2.下载安装memcachefs
mkdir memcachefs
wget http://jaist.dl.sourceforge.net/project/memcachefs/memcachefs/0.5/memcachefs-0.5.tar.gz
tar -zxvf memcachefs-0.5.tar.gz
cd memcachefs-0.5
./configure  --prefix=/home/slim/memcachefs
make
make install
cd /home/slim/memcachefs

3.挂载memcached

mkdir cache 

./memcachefs 192.168.100.110:11211 /home/slim/cache #将远程的memcache挂载到本地

查看挂载情况:mount -l

fuse on /home/slim/cache type fuse (rw,nosuid,nodev,user=slim)

注意:

1)如果报错:“./memcachefs: error while loading shared libraries: libmemcache.so.0: cannot open shared object file: No such file or directory”

将/usr/local/lib添加到/etc/ld.so.conf

#echo "/usr/local/lib" >> /etc/ld.so.conf

#/sbin/ldconfig

2)若报“fuse: failed to exec fusermount: Permission denied”,说明mount没有权限

首先确定已经加载fuse模块,并且fuse模块属于fuse组
ls -l /dev/fuse
可以看到用户是 root fuse
如果是root root
sudo chgrp fuse /dev/fuse
然后用groups命令查看当前用户所属的组,如果没有fuse,将当前用户加入
gpasswd -a  slim fuse

完成后重新登录用户

四、测试
1.基本操作

echo "helloworld" > cache/test_key #设置一个cache数据,文件名是键,文件内容是值。等同于set key value操作。
cat cache/test_key #获取cache数据。等同于get key操作。
ll cache/ #列出所有键。注意第五列不是指大小,而是表示字符长度。第六七列时间属性。
rm cache/test_key #删除cache数据,等同于delete key操作。
mv cache/x cache/x.bak #重命名
2.卸载
# mount #查看挂载
# umount cache #卸载
# fusermount -u cache #卸载
3.使用telnet客户端测试
set a 0 10 3 #10s过期。10s过后,cache目录下的a文件将被删除。
get x.bak #telnet方法获取memcachfs设置的cache数据
cat cache/a #通过memcachefs获取键a数据

你可能感兴趣的:(memcached)