Memcached是免费的,开源的,高性能的,分布式内存对象的缓存系统(键/值字典),旨在通过减轻数据库负载加快动态Web应用程序的使用。 Memcached是由布拉德·菲茨帕特里克(Brad Fitzpatrick)在2003年为LiveJournal 开发的,现在有很多知名网站都在使用,包括:Netlog, Facebook, Flickr, Wikipedia, Twitter, YouTube等。 官网地址(https://memcached.org/)
优点
- 免费开源
- 支持多种语言 (Python/Ruby/PHP/..)
缺点
- 无持久化(也就是说数据都是存在内存里)
- 不能做大对象缓存(比如图片,音频)
安装
- Mac
brew install memcached
#启动
brew services start memcached
- Linux(Ubuntu)
sudo apt install memcached
apt install libevent-2.1-6
# libevent 是依赖
使用
- 启动\停止\重启 服务
> 通过这种方式启动 最好是通过这种方式关闭
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
- -d 守护进程(daemon) 形式, 也就是在后台运行
- -p 端口 ==> 默认端口 11211
- -l host地址 ==> 默认 127.0.0.1
- -u 表示指定用户
- -m 表示指定占用的内存
- -c 连接数, 默认1024
- -P 设置报错 Memcache 的 Pid 文件
操作
原生操作
使用 Telnet 连上去,进行操作
比如:telnet 127.0.0.1 11211
- 存储
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
-
建立连接
import memcache
建立连接
mc = memcache.Client(['127.0.0.1:11211'], debug=True)
-
数据操作
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"])
网友评论