Memcached

作者: Python野路子 | 来源:发表于2018-11-13 00:04 被阅读0次

    Memcached是免费的,开源的,高性能的,分布式内存对象的缓存系统(键/值字典),旨在通过减轻数据库负载加快动态Web应用程序的使用。 Memcached是由布拉德·菲茨帕特里克(Brad Fitzpatrick)在2003年为LiveJournal 开发的,现在有很多知名网站都在使用,包括:Netlog, Facebook, Flickr, Wikipedia, Twitter, YouTube等。 官网地址(https://memcached.org/)

    优点

    1. 免费开源
    2. 支持多种语言 (Python/Ruby/PHP/..)

    缺点

    1. 无持久化(也就是说数据都是存在内存里)
    2. 不能做大对象缓存(比如图片,音频)

    安装

    • Mac
    brew install memcached
    #启动
    brew services start memcached
    
    • Linux(Ubuntu)
    sudo apt install memcached
    apt install libevent-2.1-6
    # libevent 是依赖
    

    使用

    1. 启动\停止\重启 服务
        > 通过这种方式启动 最好是通过这种方式关闭
        sudo service memcached start
        sudo service memcached stop
        sudo service memcached restart
    

    上面的限制了只能本机访问, 并不能携带参数

    # 获取帮助
    memcached -h
    #  
    memcached -d -p 11211 -l 0.0.0.0  -u root -m 64M -c 512 -P  /var/run/memcached.pid
    
    1. -d 守护进程(daemon) 形式, 也就是在后台运行
    2. -p 端口 ==> 默认端口 11211
    3. -l host地址 ==> 默认 127.0.0.1
    4. -u 表示指定用户
    5. -m 表示指定占用的内存
    6. -c 连接数, 默认1024
    7. -P 设置报错 Memcache 的 Pid 文件

    操作

    原生操作

    使用 Telnet 连上去,进行操作
    比如:telnet 127.0.0.1 11211

    1. 存储
      1.1 set 设置

    设置一个 key

    # 语法
    set key flags(0) exptime bytes
    value
    
    • key key的名字
    • flags 是一个16位的无符号整数 一般写 0
    • exptime 过期时间
    • bytes 存储的字节

    示例

    set captcha 0 60 4
    tzxw
    

    成功返回 STORED

    失败返回 ERROR

    1.2 add 添加

    添加 key

    # 语法
    add key flags(0) exptime bytes
    value
    

    示例

    add captcha 0 60 3
    qwe
    # 如果 captcha 已经存在,则返回  NOT_STORED
    

    set 和 add 的区别

    • set 如果要设置的key已经存在,再次设置则是覆盖
    • add 如果要添加的key已经存在,则返回 NOT_STORED 不存在则添加

    2.查找

    2.1. get 获取

    获取值, 如果不存在, 返回空

    # 语法
    get key
    

    示例

    get captcha
    

    2.2 delete 删除

    删除已经存在的 key , 不存在 返回 NOT_FOUND

    # 语法
    delete key
    

    示例

    delete captcha
    
    • flush_all 删除所有数据
    • stats 查看状态

    Python 操作

    使用 Python 操作,我们要安装一个 python-memcached 的包

    pip install python-memcached
    
    1. 建立连接

      import memcache

      建立连接

      mc = memcache.Client(['127.0.0.1:11211'], debug=True)

    2. 数据操作
      2.1 设置

      设置一个

      mc.set('key', 'val',time=60)

      设置多个

      mc.set_multi({"key1":"val1", "key2":"val2"}, time=60)

    2.2 获取

    # 获取一个
    mc.get('key')
    # 获取多个
    mc.get_multi(("key1", "key2"))
    

    2.3 删除

    # 删除一个
    mc.delete("key")
    # 删除多个
    mc.delete_multi(["key1", "key2"])
    

    相关文章

      网友评论

          本文标题:Memcached

          本文链接:https://www.haomeiwen.com/subject/ovghfqtx.html