Memcache文件系统memcachefs部署和使用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Memcache文件系统memcachefs部署和使用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3529字,纯文字阅读大概需要6分钟。
内容图文
![Memcache文件系统memcachefs部署和使用](/upload/InfoBanner/zyjiaocheng/561/53758a30b0b34474b4dd7ac019ca95bd.jpg)
Memcache文件系统memcachefs部署和使用介绍memcachefs是基于FUSE的memcached文件系统,将memcache服务挂载到本地。允许查看缓存中的数据,就好像是磁盘上的文件
Memcache文件系统memcachefs部署和使用
介绍
memcachefs是基于FUSE的memcached文件系统,将memcache服务挂载到本地。允许查看缓存中的数据,就好像是磁盘上的文件。memcache的操作都将转换成针对普通文件般的操作。
项目地址:
使用场景
基于本地磁盘缓存文件都可以用memcachefs来实现,效率上比磁盘更强大。。比如session文件等等。 如果先前的session信息就存在本地磁盘上,可以直接将memcache挂载到当前session目录上,无需更改程序,完美解决。
安装
1.安装依赖(使用root安装)
依赖
FUSE 2.5 or later
libmemcache 1.4 or later
a)安装fuse-2.9.3.tar.gz
cd /tmp wget tar zxvf fuse-2.9.3.tar.gz cd fuse-2.9.3 ./configure make make installb)挂载fuse内核模块
modprobe fuse lsmod | grep "fuse"c)安装libmemcache-1.4.0.rc2.tar.bz2
cd /tmp wget ~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编译出错,输出如下:
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解决方法,参考:
wget 'http://svnweb.freebsd.org/ports/head/databases/libmemcache/files/patch-fix-inline?revision=248965&view=co' -O libcache.patch patch -p0 < libcache.patch再次
make make install
2.下载安装memcachefs
mkdir /usr/local/memcachefs cd /tmp wget 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
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
echo "/usr/local/lib" >> /etc/ld.so.conf /sbin/ldconfig查看挂载情况:
mount -lmemcachefs on /usr/local/cache type fuse.memcachefs (rw,nosuid,nodev)
使用
1.基本操作
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.卸载
# 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数据
[root@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. [root@test01 local]# cat cache/a aaa本文出自 “SQL Server Deep Dives” 博客,请务必保留此出处
内容总结
以上是互联网集市为您收集整理的Memcache文件系统memcachefs部署和使用全部内容,希望文章能够帮你解决Memcache文件系统memcachefs部署和使用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。