热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Memcache文件系统memcachefs部署和使用-mysql教程

Memcache文件系统memcachefs部署和使用介绍memcachefs是基于FUSE的memcached文件系统,将memcache服务挂载到本地。允许查看缓存中的数据,就好像是磁盘上的文件

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 install


    b)挂载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

    再次

    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 -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


    本文出自 “SQL Server Deep Dives” 博客,请务必保留此出处

    推荐阅读
    • 本文深入探讨了NoSQL数据库的四大主要类型:键值对存储、文档存储、列式存储和图数据库。NoSQL(Not Only SQL)是指一系列非关系型数据库系统,它们不依赖于固定模式的数据存储方式,能够灵活处理大规模、高并发的数据需求。键值对存储适用于简单的数据结构;文档存储支持复杂的数据对象;列式存储优化了大数据量的读写性能;而图数据库则擅长处理复杂的关系网络。每种类型的NoSQL数据库都有其独特的优势和应用场景,本文将详细分析它们的特点及应用实例。 ... [详细]
    • 本文详细介绍了在 Windows 7 上安装和配置 PHP 5.4 的 Memcached 分布式缓存系统的方法,旨在减少数据库的频繁访问,提高应用程序的响应速度。 ... [详细]
    • 分布式开源任务调度框架 TBSchedule 深度解析与应用实践
      本文深入解析了分布式开源任务调度框架 TBSchedule 的核心原理与应用场景,并通过实际案例详细介绍了其部署与使用方法。首先,从源码下载开始,详细阐述了 TBSchedule 的安装步骤和配置要点。接着,探讨了该框架在大规模分布式环境中的性能优化策略,以及如何通过灵活的任务调度机制提升系统效率。最后,结合具体实例,展示了 TBSchedule 在实际项目中的应用效果,为开发者提供了宝贵的实践经验。 ... [详细]
    • 最近,我在CentOS 5服务器上成功部署了GForge 5.7 Community Edition。与Advanced Server版本相比,虽然功能略有简化,但仍然能够满足大多数开源项目管理的需求。为了确保数据安全,我开发了一套全自动备份脚本,该脚本能够定期备份GForge的数据和配置文件,并将其存储在远程服务器上,以防止数据丢失。此外,该脚本还具备错误检测和日志记录功能,便于故障排查和维护。 ... [详细]
    • Mantis Bug Tracker:高效缺陷管理与跟踪系统
      缺陷管理平台Mantis,也做MantisBT,全称MantisBugTracker。Mantis是一个基于PHP技术的轻量级的开源缺陷跟踪系统,以Web操作的形式提供项目管理及缺 ... [详细]
    • 本文介绍了Android SDK Platform Tools的核心功能及其重要性。作为Android SDK的一个关键组成部分,Platform Tools提供了开发者与Android设备进行交互所需的各种工具。 ... [详细]
    • 本文档提供了详细的MySQL安装步骤,包括解压安装文件、选择安装类型、配置MySQL服务以及设置管理员密码等关键环节,帮助用户顺利完成MySQL的安装。 ... [详细]
    • 本文探讨了HTA(HTML Application)环境中HTML5 IndexedDB的可用性问题,并提供了一种替代方案,即通过使用COM ActiveX对象来实现数据存储功能。 ... [详细]
    • 本文介绍了多种将多行数据合并为单行的方法,包括使用动态SQL、函数、CTE等技术,适用于不同的SQL Server版本。 ... [详细]
    • SQLite是一种轻量级的关系型数据库管理系统,尽管体积小巧,却能支持高达2TB的数据库容量,每个数据库以单个文件形式存储。本文将详细介绍SQLite在Android开发中的应用,包括其数据存储机制、事务处理方式及数据类型的动态特性。 ... [详细]
    • 帝国cms各数据表有什么用
      CMS教程|帝国CMS帝国cmsCMS教程-帝国CMS精易编程助手源码,ubuntu桥接设置,500错误是tomcat吗,爬虫c原理,php会话包括什么,营销seo关键词优化一般多 ... [详细]
    • 构建Python自助式数据查询系统
      在现代数据密集型环境中,业务团队频繁需要从数据库中提取特定信息。为了提高效率并减少IT部门的工作负担,本文探讨了一种利用Python语言实现的自助数据查询工具的设计与实现。 ... [详细]
    • 转载于:https:blog.51cto.comquieth ... [详细]
    • svn切换账号后无法update_刺激战场国际服疑似锁国区 新玩家无法注册 玩家务必不要切换账号...
      作为绝地求生官方授权的正版手游,《PUBGMobile》受到全世界诸多玩家的青睐,这其中就包括众多国内玩家。自从《和平精英》上线之后,大量 ... [详细]
    • 在 Virtmanager 图形界面中使用桥接网络
      在Virt-manager图形界面中使用桥接网络(bridgednetworking)2012-09-0315:40:23标签:virtm ... [详细]
    author-avatar
    手机用户2502923697
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有