Flask-论坛开发-5-memcached缓存系统
对Flask感兴趣的,可以看下这个视频教程:http://study.163.com/course/courseLearn.htm?courseId=1004091002
### 介绍:
哪些情况下适合使用 memcached 呢?存储验证码(图形验证码、短信验证码),登录 session 等所有不是至关重要且被访问到的几率较大的数据。
### 安装(Windows):
使用 cmd 进入到对应目录,执行 memcached.exe -d install
### 启用(管理员权限):
使用 cmd 进入到对应目录,执行 memcached.exe -d start
### 启动时的参数:
-d 让 memcached 在后台运行
-m 指定最多能占用多少内存,以 M 为单位,默认 64M,超出后会新数据会替换掉最开始的数据
-p 指定占用的端口,默认 11211
-l 指定哪些 ip 可以连接,如(-l 0.0.0.0 代表所有机器都能连接)默认只能通过本机连接
### 查看是否启用:
打开任务管理器,点击 [服务] 选项,若存在 memcached 服务则说明已经启用
### 可能出现的问题:
1. 提示没有权限:打开 cmd 的时候使用管理员的身份
2. 缺少 pthreadGC2.dll 文件:将 pthreadGC2.dll 文件拷贝到 windows/System32 目录下
3. 不要放在含有中文字符的路径下
### telnet 连接 memcached 格式:telnet ip port
### 如何验证 telnet 已经连接上 memcached 了?
set username myyd 0 60 3 # 创建一个数据,名字为 myyd ,0 代表是否需要压缩,存储 60 秒,其值只能包含 3 个字符
abc # 输入 myyd 对应的值
get username # 获取 username 对应的名字和值
quit # 退出
### memcached 语法(memcached 以键值对的方式存储数据)
登录: telnet [ip] [port]
## set:创建一个新的数据,格式如下:
> set username 0 120 4 # 其中,username 是 key,MYYD 是 value,0 代表不压缩,120 代表过期时间(s),4 代表值只能是 4 个字节
> MYYD
## get:获取指定数据,如:
> get username
## delete:删除指定数据,如:
> delete username
## flush_all:清除 memcached 中的所有数据
## incr:给 key 的值执行相加操作,格式如下:
> set age 0 120 2
> 18
> incr age 2 # 只能对数值类型进行相加
> get age # 会得到 20
## decr:给 key 的值执行相减操作,格式如下:
> set age 0 120 2
> 18
> decr age 2 # 只能对数值类型进行相加
> get age # 会得到 16
## stats:查看 memcached 的相关信息,最常用的是查看 get 命中率(get 时是从 memcached 中获取的概率)。但实际上还可以看其他的信息,如下:
> stats
> STAT get_miss 2 # get miss 次数
> STAT get_hits 2 # get hits 次数
> STAT curr_items 1 # 当前 memcached 中总共有多少键值对
> 等等
### 使用 python 操作 memcached:
1. 连接 memcached
import memcache
mc = memcache.Client(['127.0.0.1:11211'],debug=True)
2. 设置键值对
mc.set('username','MYYD',time=120) # 不需要设置值的长度,time 为过期时间(单位s),默认为 0,0 代表永不过期
3. 设置多个键值对
mc.set_multi({'username':'MYYD','age':'18'},time=120) # 设置多个键值对时,传入一个字典
4. 获取指定数据
username = mc.get('username')
print(username)
5. 删除指定数据
mc.delete('username')
6. 给 key 的值执行相加操作(可以应用在文章的阅读量上)
mc.incr('age') # 默认在原来的基础上加 1
mc.incr('age',delta=5) # 若指定了 delta 则可以自定义增长数
7. 给 key 的值执行相减操作
mc.decr('age') # 默认在原来的基础上减 1
mc.decr('age',delta=5) # 若指定了 delta 则可以自定义递减数
8. memcached 分布式存储
所谓 memcached 分布式存储,就是启用多台服务器去存储 memcached 数据,实现 memcached 分布式存储的方式如下:
mc = memcache.Client(['127.0.0.1:11211','192.168.110.110:11211'],debug=True) # 在连接时候传入开启了 memcached 服务的机器的 IP 地址即可
当你 set 数据的时候,会存入不同的服务器中,达到分布式存储的功能。
Flask-论坛开发-5-memcached缓存系统的更多相关文章
- Linux下搭建Memcached缓存系统
首先说下抱歉,博主近期单位经常加班.博客更新有点慢.希望大家理解,草稿箱里存了不少内容,等不忙时候一点点填坑~ 在一般的站点开发学习时候.都会把数据存放在RDBMS(关系型数据库系统(Relation ...
- Memcached 缓存系统简介
memcached官网:http://memcached.org/ What is Memcached? Memcached是一个自由开源的,高性能,高并发,分布式内存对象缓存系统. Memcache ...
- 6.memcached缓存系统
1.memcached的安装和参数 memcached缓存系统一般还是部署在linux服务器上,所以这里只介绍linux上memcache的安装 首先切换到root用户,然后apt-get insta ...
- (转)实战Memcached缓存系统(7)Memcached的一些基础FAQ
1. Memcached是什么? Memcached是分布式的内存对象缓存系统. 2. Memcached的基本数据结构是什么? Memcached是基于Key/Value对的HashMap.每一对, ...
- (转)实战Memcached缓存系统(1)Memcached基础及示例程序
1.Cache定义 (1)狭义概念:用于CPU的相对高速处理与主存(Main Memory)的相对低速处理的之间起到协调功能的硬件设备. (2)广义概念:用于速度相差较大的两种硬件之间,起到协调两者数 ...
- django之memcached缓存系统
django其他缓存方法:(https://www.cnblogs.com/jishuweiwang/p/6110809.html) memcached版本 <1.5 1. memcached缓 ...
- (转)实战Memcached缓存系统(8)Memcached异步实时读写问题的解决方案SAC
在使用Memcached时,一般实时读写的场景并不多见.但多是Memcached写入后,在一定时间后才会有读操作.但是如果应用场景,是写入后瞬间即会有读操作呢?似乎没有什么特别之处,我们依然可以这样写 ...
- (转)实战Memcached缓存系统(4)Memcached的CAS协议
1. 什么是CAS协议 很多中文的资料都不会告诉大家CAS的全称是什么,不过一定不要把CAS当作中国科学院(China Academy of Sciences)的缩写.Google.com一下,CAS ...
- (转)实战Memcached缓存系统(3)Memcached配置参数初解
一.基本参数 在我们第一次安装Memcached时,一般都是用过这个命令: memcached -m 512 -u root -d -l 127.0.0.1 -p 11211 我们先来解释这几个参数的 ...
- memcached学习笔记5--socke操作memcached 缓存系统
使用条件:当我们没有权限或者不能使用服务器的时候,我们需要用socket操作memcached memcached-client操作 特点: 无需开启memcache扩展 使用fsocketopen( ...
随机推荐
- codechef Row and Column Operations 题解
版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/,未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...
- Springboot 使用 RestTemplate
每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code spring web 项目提供的RestTemplate,使java访问url更方便, ...
- 统计单词数 OpenJ_Bailian - 4030(字符串处理)
一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章中 ...
- 【转】Android 关于arm64-v8a、armeabi-v7a、armeabi、x86下的so文件兼容问题
转载地址:http://blog.csdn.net/ouyang_peng/article/details/51168072 Android 设备的CPU类型(通常称为”ABIs”) x86: 平板. ...
- 【转】MySQL理解索引、添加索引的原则
索引用于快速找出在某个列中有一特定值的行.不使用索引,MySQL必须从第1条记录开始然后读完整个表直到找出相关的行,还需要考虑每次读入数据页的IO开销.而如果采取索引,则可以根据索引指向的页以及记录在 ...
- 使用ElasticSearch服务从MySQL同步数据实现搜索即时提示与全文搜索功能
最近用了几天时间为公司项目集成了全文搜索引擎,项目初步目标是用于搜索框的即时提示.数据需要从MySQL中同步过来,因为数据不小,因此需要考虑初次同步后进行持续的增量同步.这里用到的开源服务就是Elas ...
- linux grep 的使用
常用的 grep 选项有: -c 只输出匹配行的个数. -i 不区分大小写(只适用于单字符). -h 查询多文件时不显示文件名. -l 查询多文件时只输出包含匹配字符的文件名. ...
- Qt+QGIS二次开发:QGIS里的编程模型
项目(QgsProject) 用于读写项目状态 图层分组(QgsLayerTreeGroup) 项目树的分组节点,用来存放图层节点. 图层节点(QgsLayerTreeLayer) 项目树的图层节点. ...
- ASP.NET quartz 定时任务
1.下载 2.使用例子 Demo 概述:Quartz 是开源的定时任务工具类,默认每隔10秒执行一次任务,相当于C#的Timer,不断的循环执行(Start 方法),也可以随时停止(ShutDown方 ...
- java 日期与时间类
1.Date类: https://www.cnblogs.com/huangminwen/p/5994927.html 2.DateFormat和SimpleDateFormat (simple简单 ...