Memcache文件体系memcachefs布置和运用51CTO博客 - 凯发娱乐

Memcache文件体系memcachefs布置和运用51CTO博客

2019年03月01日14时54分59秒 | 作者: 恨蕊 | 标签: 文件,运用,挂载 | 浏览: 1682

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

cd /tmp
wget http://hivelocity.dl.sourceforge.net/project/fuse/fuse-2.X/2.9.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内核模块

modprobe fuse
lsmod | grep "fuse"


c)装置libmemcache-1.4.0.rc2.tar.bz2

cd /tmp
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


编译犯错,输出如下:

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

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 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=/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 -l

memcachefs 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


版权声明
本文来源于网络,版权归原作者所有,其内容与观点不代表凯发娱乐立场。转载文章仅为传播更有价值的信息,如采编人员采编有误或者版权原因,请与我们联系,我们核实后立即修改或删除。

猜您喜欢的文章

阅读排行

  • 1
  • 2
  • 3
  • 4
  • 5

    SQL对日期相关操作ITeye

    本季度,项目,天数
  • 6

    SQL对日期相关操作ITeye

    本季度,项目,天数
  • 7

    MongoDB 入门ITeye

    发动,效劳,指令
  • 8

    MongoDB 入门ITeye

    发动,效劳,指令
  • 9

    imp导入报表空间不存在的过错ITeye

    空间,数据库,数据文件
  • 10

    ORACLE 最大衔接ITeye

    数据库,修正,检查