V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
char1998
V2EX  ›  memcached

学习 memcached 的一些记录

  •  
  •   char1998 · 2017-03-05 17:50:31 +08:00 · 4313 次点击
    这是一个创建于 2813 天前的主题,其中的信息可能已经有所发展或是发生改变。

    memcached 介绍

    什么是 memcached :

    1. memcached之前是danga的一个项目,最早是为 LiveJournal 服务的,当初设计师为了加速 LiveJournal 访问速度而开发的,后来被很多大型项目采用。官网是www.danga.com或者是memcached.org
    2. Memcached是一个高性能的分布式内存对象缓存系统,全世界有不少公司采用这个缓存项目来构建大负载的网站,来分担数据库的压力。 Memcached是通过在内存里维护一个统一的巨大的 hash 表,memcached能存储各种各样的数据,包括图像、视频、文件、以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

    特征 :

    memcached 作为高速运行的分布式缓存服务器,具有以下的特点。

    • 协议简单
    • 基于 libevent 的事件处理
    • 内置内存存储方式
    • memcached 不互相通信的分布式

    支持的语言:

    许多语言都实现了连接memcached的客户端,其中以 Perl 、 PHP 为主。仅仅memcached网站上列出的有:

    • Perl
    • PHP
    • Python
    • Ruby
    • C#
    • C/C++
    • Lua
    • 等等

    Memcached 用户:

    • LiveJournal
    • Wikipedia
    • Flickr
    • Bebo
    • Twitter
    • Typepad
    • Yellowbot
    • Youtube
    • WordPress.com
    • Craigslist
    • Mixi

    安装和启动memcached

    1. windows :

      • 安装:memcached.exe -d install
      • 启动:memcached.exe -d start
    2. linux ( Ubuntu/Debian ):

      • 安装:sudo apt-get install memcached
      • 启动:sudo service memcached start
    3. linux ( Redhat/Fedora/Centos ):

      • 安装:yum install memcached
      • 启动:yum service memcached start
    4. 可能出现的问题:

      • 提示你没有权限:在打开 cmd 的时候,右键使用管理员身份运行。
      • 提示缺少pthreadGC2.dll文件:将pthreadGC2.dll文件拷贝到windows/System32.
      • 不要放在含有中文的路径下面。
    5. 启动memcached

      • -d:这个参数是让memcached在后台运行。
      • -m:指定占用多少内存。
      • -p:指定占用的端口。默认端口是11211
      • -l:哪些 ip 地址可以链接。

    telnet操作memcached

    1. 添加数据:
      • set
        • 语法:

          set key flas(0) timeout value_length
          value
          
        • 示例:

          set username 0 60 7
          xiaotuo
          
      • add
        • 语法:

          add key flas(0) timeout value_length
          value
          
        • 示例:

          add username 0 60 7
          xiaotuo
          

    setadd的区别:add是只负责添加数据,不会去修改数据。如果添加的数据的key已经存在了,则添加失败,如果添加的key不存在,则添加成功。而set不同,如果memcached中不存在相同的key,则进行添加,如果存在,则替换。

    1. 获取数据:

      • 语法:
        get key
        
      • 示例:
        get username
        
    2. 删除数据:

      • 语法:
        delete key
        
      • 示例:
        delete username
        
      • flush_all:删除memcached中的所有数据。
    3. 查看memcached的当前状态:

      • 语法:stats
    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2897 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 14:40 · PVG 22:40 · LAX 06:40 · JFK 09:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.