Memcached

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)