设为首页 收藏本站
查看: 1413|回复: 0

[经验分享] Memcache文件系统memcachefs部署和使用

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-5-6 09:06:22 | 显示全部楼层 |阅读模式
Memcache文件系统memcachefs部署和使用


介绍

memcachefs是基于FUSE的memcached文件系统,将memcache服务挂载到本地。允许查看缓存中的数据,就好像是磁盘上的文件。memcache的操作都将转换成针对普通文件般的操作。

项目地址:http://memcachefs.sourceforge.net/

使用场景

基于本地磁盘缓存文件都可以用memcachefs来实现,效率上比磁盘更强大。。比如session文件等等。 如果先前的session信息就存在本地磁盘上,可以直接将memcache挂载到当前session目录上,无需更改程序,完美解决。

安装

1.安装依赖(使用root安装)

依赖
  • FUSE 2.5 or later
  • libmemcache 1.4 or later


a)安装fuse-2.9.3.tar.gz
1
2
3
4
5
6
7
cd /tmp
wget http://hivelocity.dl.sourceforge ... 3/fuse-2.9.3.tar.gz
tar zxvf fuse-2.9.3.tar.gz
cd fuse-2.9.3
./configure
make
make install




b)挂载fuse内核模块
1
2
modprobe fuse
lsmod | grep "fuse"




c)安装libmemcache-1.4.0.rc2.tar.bz2
1
2
3
4
5
6
cd /tmp
wget http://people.freebsd.org/~seanc ... e-1.4.0.rc2.tar.bz2
tar xvf libmemcache-1.4.0.rc2.tar.bz2
cd libmemcache-1.4.0.rc2
./configure
make




编译出错,输出如下:
1
2
3
4
5
6
7
memcache.c: At top level:
../include/memcache/buffer.h:73: warning: inline function 'mcm_buf_remain_off' declared but never defined
../include/memcache/buffer.h:72: warning: inline function 'mcm_buf_remain' declared but never defined
../include/memcache/buffer.h:66: warning: inline function 'mcm_buf_len' declared but never defined
../include/memcache/buffer.h:73: warning: inline function 'mcm_buf_remain_off' declared but never defined
../include/memcache/buffer.h:72: warning: inline function 'mcm_buf_remain' declared but never defined
../include/memcache/buffer.h:66: warning: inline function 'mcm_buf_len' declared but never defined




解决方法,参考:
http://pietercvdmlinux.blogspot.com/2012_07_01_archive.html
1
2
wget 'http://svnweb.freebsd.org/ports/head/databases/libmemcache/files/patch-fix-inline?revision=248965&view=co' -O libcache.patch
patch -p0 < libcache.patch




再次
1
2
make
make install




2.下载安装memcachefs
1
2
3
4
5
6
7
8
9
mkdir /usr/local/memcachefs
cd /tmp
wget http://jaist.dl.sourceforge.net/ ... mcachefs-0.5.tar.gz
tar -zxvf memcachefs-0.5.tar.gz
cd memcachefs-0.5
./configure --prefix=/usr/local/memcachefs
make
make install
cd /usr/local/memcachefs




3.挂载memcached
1
2
mkdir /usr/local/cache
./bin/memcachefs 192.168.11.52:11211 /usr/local/cache #将远程的memcache挂载到本地




报错如下:
“./bin/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
1
2
echo "/usr/local/lib" >> /etc/ld.so.conf
/sbin/ldconfig




查看挂载情况:
1
mount -l



memcachefs on /usr/local/cache type fuse.memcachefs (rw,nosuid,nodev)

使用

1.基本操作
1
2
3
4
5
6
cd /usr/local
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/username cache/username.bak #重命名




2.卸载
1
2
3
# mount #查看挂载
# umount /usr/local/cache #卸载
# fusermount -u /usr/local/cache #卸载




3.使用telnet客户端测试

set a 0 10 3 #10s过期。10s过后,cache目录下的a文件将被删除。
get username.bak #telnet方法获取memcachfs设置的cache数据
cat cache/a #通过memcachefs获取键a数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[iyunv@test01 local]# telnet 192.168.11.52 11211
Trying 192.168.11.52...
Connected to 192.168.11.52.
Escape character is '^]'.
set a 0 10 3
aaa
STORED
get username.bak
VALUE username.bak 0 6
ryanxu
END
quit
Connection closed by foreign host.
[iyunv@test01 local]# cat cache/a
aaa






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-64061-1-1.html 上篇帖子: magent + memcached 集群测试 下篇帖子: centos6.5系统中安装配置memcached步骤
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表