兄弟连学python—Redis简介及应用

  1   ##Redis
  2
  3     Redis是一个开源的,先进的key-value存储。
  4     它通常被称为数据结构服务器,因为键可以包含字符串,哈希,链表,集合和有序集合。
  5
  6
  7 ###Redis 简介
  8     Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
  9     Redis 与其他 key - value 缓存产品有以下三个特点:
 10     Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
 11     Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
 12     Redis支持数据的备份,即master-slave模式的数据备份。(主--从)
 13
 14 ###Redis 优势
 15     性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
 16     丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作
 17     原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
 18     丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
 19
 20 ###Redis与其他key-value存储有什么不同?
 21     Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。
 22     Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。
 23     Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,
 24     因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,
 25     在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。
 26     同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。
 27
 28
 29 ###Redis 安装
 30
 31 ####Window 下安装
 32
 33     一.安装redis服务
 34
 35     Redis 支持 32 位和 64 位。这个需要根据你系统平台的实际情况选择,
 36     这里我们下载 32位 Redis-Windows-32bit.zip压缩包到 C 盘,解压后,将文件夹重新命名为redis。
 37
 38     打开一个 cmd 窗口 使用cd命令切换目录到 C:\redis 运行 redis-server.exe redis.windows.conf 。
 39     后面的那个 redis.windows.conf 可以省略,如果省略,会启用默认的。
 40
 41     这时候另再开启一个cmd窗口,原来的不要关闭,不然就无法访问服务端了。
 42     切换到redis目录下运行 redis-cli.exe -h 127.0.0.1 -p 6379 。
 43
 44     按照上面的运行是可以的,但是这样就会造成两个命令行窗口都要开启,特别是服务器端,一旦关闭了那么客户端就无法使用了,那么这样可以把redis服务安装到windows服务里面
 45
 46     Redis是可以安装成windows服务的,开机自启动,命令如下:
 47     redis-server --service-install redis.windows.conf
 48
 49     Redis并没有启动,启动命令如下:
 50     redis-server --service-start
 51
 52     停止命令:
 53     redis-server --service-stop
 54
 55     卸载命令:
 56     redis-server --service-uninstall
 57
 58
 59
 60     二.安装php redis扩展
 61
 62       1.phpinfo检测是否开启
 63
 64       2.php扩展目录 extension_dir
 65         php_redis.dll放置到php扩展目录下
 66
 67       3.php配置文件修改
 68         extension=php_redis.dll
 69
 70       4.重启服务apache服务
 71
 72 ####Ubuntu 下安装
 73
 74     在 Ubuntu 系统安装 Redi 可以使用以下命令:
 75
 76     $sudo apt-get update
 77     $sudo apt-get install redis-server
 78
 79     启动 Redis
 80
 81     $ redis-server
 82
 83     查看 redis 是否启动?
 84
 85     $ redis-cli
 86
 87     以上命令将打开以下终端:
 88
 89     redis 127.0.0.1:6379>
 90
 91     127.0.0.1 是本机 IP ,6379 是 redis 服务端口。现在我们输入 PING 命令。
 92
 93     redis 127.0.0.1:6379> ping
 94     PONG
 95
 96     以上说明我们已经成功安装了redis。
 97
 98
 99
100 ##Redis 数据类型
101     Redis支持五种数据类型:
102         string(字符串)
103         list(列表)
104         set(集合)
105         zset(有序集合)
106         hash(哈希)
107
108
109 ####String(字符串)
110     string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
111     string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
112     string类型是Redis最基本的数据类型,一个键最大能存储512MB。
113
114
115 #####实例
116     redis 127.0.0.1:6379> SET name "runoob"
117     OK
118     redis 127.0.0.1:6379> GET name
119     "runoob"
120     在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 name,对应的值为 runoob。
121     注意:一个键最大能存储512MB。
122     --------------------------------------------
123        set 命令:设置一个键和值,键存在则只覆盖,返回ok
124        > set 键  值
125        例如: >set name zhangsan
126
127        get 命令:获取一个键的值,返回值
128        > get 键        例如:>get name
129
130        setnx命令:设置一个不存在的键和值(防止覆盖),
131        > setnx 键 值      若键已存在则返回0表示失败
132
133        setex命令:设置一个指定有效期的键和值(单位秒)
134        > setex 键 [有效时间] 值
135        例如: >setex color 10 red
136         不写有效时间则表示永久有效,等价于set
137
138        setrange命令:替换子字符串 (替换长度由子子串长度决定)
139        > setrange 键 位置 子字串
140        > setrange name 4 aa  将name键对应值的第4个位置开始替换
141
142        mset命令:批量设置键和值,成功则返回ok
143        > mset 键1 值1 键2 值2 键3 值3 ....
144
145        msetnx命令:批量设置不存在的键和值,成功则返回ok
146        > msetnx 键1 值1 键2 值2 键3 值3 ....
147
148        getset命令:获取原值,并设置新值
149
150        getrange命令:获取指定范围的值
151        >getrange 键 0 4     //获取指定0到4位置上的值
152
153        mget命令: 批量获取值
154        >mget 键1 键2 键3....
155
156        incr命令: 指定键的值做加加操作,返回加后的结果。
157        >  键        例如: >incr kid
158        incrby命令: 设置某个键加上指定值
159        > incrby 键 m    //其中m可以是正整数或负整数
160
161        decr命令: 指定键的值做减减操作,返回减后的结果。
162        > decr 键        例如: >decr kid
163        decrby命令: 设置某个键减上指定值
164        > decrby 键 m    //其中m可以是正整数或负整数
165
166        append命令:给指定key的字符串追加value,返回新字符串值的长度
167        >append 键 追加字串
168
169        strlen求长度
170        >strlen 键名   //返回对应的值。
171
172
173
174 ####List(列表)
175     Redis 列表是简单的字符串列表,按照插入顺序排序。
176     你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
177 #####实例
178     redis 127.0.0.1:6379> lpush runoob redis
179     (integer) 1
180     redis 127.0.0.1:6379> lpush runoob mongodb
181     (integer) 2
182     redis 127.0.0.1:6379> lpush runoob rabitmq
183     (integer) 3
184     redis 127.0.0.1:6379> lrange runoob 0 10
185     1) "rabitmq"
186     2) "mongodb"
187     3) "redis"
188     redis 127.0.0.1:6379>
189     列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
190
191     --------------------------------------------
192        list即可以作为“栈”也可以作为"队列"。
193     操作:
194      >lpush list1 "world"  //在list1头部压入一个字串
195      >lpush list1 "hello"  // 在list1头部压入一个字串
196      >lrange list1 0 -1  //获取list1中内容
197         0:表示开头  -1表示结尾。
198
199      >rpush list2 "world"  //在list2尾部压入一个字串
200      >rpush list2 "hello"  // 在list2尾部压入一个字串
201      >lrange list2 0 -1  //获取list2中内容
202         0:表示开头  -1表示结尾。
203
204      >linsert list2 before hello there
205      在key对应list的特定位置前或后添加字符串
206
207      >lset list2 1 "four"
208      修改指定索引位置上的值
209
210      >lrem list2 2 "hello"  //删除前两个hello值
211      >lrem list2 -2 "hello" //删除后两个hello值
212      >lrem list2 0 "hello"  //删除所有hello值
213
214      >ltrim mylist8 1 3    //删除此范围外的值
215
216      >lpop list2   //从list2的头部删除元素,并返回删除元素
217      >rpop list2   //从list2的尾部删除元素,并返回删除元素
218      >rpoplpush list1 list2    //将list1的尾部一个元素移出到list2头部。并返回
219
220      >lindex list2 1 //返回list2中索引位置上的元素
221      >llen list2 //返回list2上长度
222
223 ####Set(无序集合)
224     Redis的Set是string类型的无序集合。
225     集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
226     sadd 命令
227     添加一个string元素到,key对应的set集合中,
228     成功返回1,如果元素已经在集合中返回0,key对应的set不存在返回错误。
229     sadd key member
230 #####实例
231     redis 127.0.0.1:6379> sadd runoob redis
232     (integer) 1
233     redis 127.0.0.1:6379> sadd runoob mongodb
234     (integer) 1
235     redis 127.0.0.1:6379> sadd runoob rabitmq
236     (integer) 1
237     redis 127.0.0.1:6379> sadd runoob rabitmq
238     (integer) 0
239     redis 127.0.0.1:6379> smembers runoob
240
241     1) "rabitmq"
242     2) "mongodb"
243     3) "redis"
244     注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
245     集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
246
247     -------------------------------
248      >sadd myset "hello" //向myset中添加一个元素
249       成功返回1,失败(重复)返回0
250
251      >smembers myset //获取myset中的所有元素(结果是无序的)
252
253      >srem myset "one" //从myset中删除一个one
254       成功返回1,失败(不存在)返回0
255
256      >spop myset //随机返回并删除myset中的一个元素
257      >srandmember myset //随机获取myset中的一个元素,但是不删除
258
259      > smove myset1 myset2 zhangsan:将myset1中zhangsan移动到myset2中
260      > scard myset1 返回myset1的个数
261      > sismember myset zhangsan:判断张三是否在myset中
262
263      >sdiff myset1 myset2 //返回两个集合的差集
264      以myset1为标准,获取myset2中不存在的。
265      >sdiffstore dstset myset1 myset2 ...// 返回所有集合的差集,并保存到dstset中
266
267      >sinter myset1 myset2 myset3... // 返回N个集合中的交集
268      >sinterstore dstset myset1 myset2 ... // 返回N个集合的交集并存储到dstset中
269
270      > sunion myset1 myset2 ...//返回所有集合的并集
271      > sunionstore dstset myset1 myset2// 返回所有集合的并集,并存储到dstset中
272
273 ####zset(sorted set:有序集合)
274     Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
275     不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
276     zset的成员是唯一的,但分数(score)却可以重复。
277     zadd 命令
278     添加元素到集合,元素在集合中存在则更新对应score
279     zadd key score member
280 #####实例
281     redis 127.0.0.1:6379> zadd runoob 0 redis
282     (integer) 1
283     redis 127.0.0.1:6379> zadd runoob 0 mongodb
284     (integer) 1
285     redis 127.0.0.1:6379> zadd runoob 0 rabitmq
286     (integer) 1
287     redis 127.0.0.1:6379> zadd runoob 0 rabitmq
288     (integer) 0
289     redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 0 1000
290
291     1) "redis"
292     2) "mongodb"
293     3) "rabitmq"
294
295     ----------------------------------------
296
297      > zadd zset 1 one 向zset中添加one,排序为1排序
298      > zrem zset one:删除zset中one
299
300      > zincrby zset 2 one:如果one存在,则顺序增加2,如果one不存在,那么就是2
301
302      > zrank zset one:返回one在zset中排名(从小到大的排序)
303      > zrevrank zset one:返回one在zset中排名(从大到小的排序)
304
305      > zrange zset 0 -1 withscores:根据score排序(根据score从小到大排序)
306      > zrevrange zset 0 -1 withscores:根据score排序(根据score从大到小排序)
307
308      > zrangebyscore zset 2 3 withscores:返回集合中score在给定区间的元素(包含2和5)
309      > zcount zset 2 3:返回集合中给定区间的数量
310      > zcard zset:返回集合中元素的个数
311      > zscore zset one:返回one元素的score
312      > zremrangebyrank zset 3 3:删除集合中排名在给定区间的元素
313      > zremrangebyscore zset 1 2:将zset中从小到大排序结果的score在1-2之间的删除
314
315
316 ####Hash(哈希)
317     Redis hash 是一个键值对集合。
318     Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
319 #####实例
320     127.0.0.1:6379> HMSET user:1 username runoob password runoob points 200
321     OK
322     127.0.0.1:6379> HGETALL user:1
323     1) "username"
324     2) "runoob"
325     3) "password"
326     4) "runoob"
327     5) "points"
328     6) "200"
329     以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。
330     实例中我们使用了 Redis HMSET, HGETALL 命令,user:1 为键值。
331     每个 hash 可以存储 232 -1 键值对(40多亿)。
332     ------------------------------------------
333     hset命令:设置一个哈希表的键和值
334       >hset hash名 键  值
335       如:>hset user:001 name zhangsan
336       hget命令: 获取执行哈希名中的键对应值
337
338       hsetnx命令:设置一个哈希表中不存在的键和值
339       >hsetnx hash名 键  值  //成功返回1,失败返回0
340       如:>hsetnx user:001 name zhangsan
341
342       hmset命令:hmset user:001 username zhangsan age 20 sex 1 批量设置
343       hmget user:001 username age sex:批量获取值
344
345       >hexists user:001 name //是否存在, 若存在返回1
346
347       >hlen user:001  //获取某哈希user001名中键的数量
348
349       >hdel user:001 name //删除哈希user:001 中name键
350
351       >hkeys user:002   //返回哈希名为user:002中的所有键。
352       >hvals user:002   //返回哈希名为user:002中的所有值。
353       >hgetall user:002 //返回哈希名为user:002中的所有键和值。
354
355
356
357
358
359 #Redis高级实用特性
360
361 1. 安全性:为Redis添加密码
362 ------------------------------------------
363     警告:因为redis 速度相当快,所以在一台比较好的服务器下,
364     一个外部的用户可以在一秒钟进行150K 次的密码尝试,
365     这意味着你需要指定非常非常强大的密码来防止暴力破解。
366
367     1.进入配置文件:
368      vi /usr/local/redis/etc/redis.conf
369      设置:requirepass redis的密码
370     2. 重启服务:
371     # ./redis-cli shutdown 执行关闭
372     # ./redis-server /usr/local/redis/etc/redis.conf  启动
373     3. 登录(两种)
374     # ./redis-cli 客户端命令链接服务器
375     >auth 密码值  //授权后方可使用
376
377     # ./redis-cli -a  密码 //连接时指定密码来进行授权
时间: 2024-11-05 13:39:50

兄弟连学python—Redis简介及应用的相关文章

兄弟连学python 课堂笔记 ---- Redis类型

Redis通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Hash), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型. String(子串类型) set 命令:设置一个键和值,键存在则只覆盖,返回ok > set 键  值    例如: >set name zhangsan get 命令:获取一个键的值,返回值 > get 键        例如:>get name setnx命令:设置一个不存在的键和值(

兄弟连学python 课堂笔记 ---- Redis基本操作

基本操作 Redis 是 Key-Value 内存数据库,操作是通过各种指令进行的,比如 `SET` 指令可以设置键值对,而 `GET` 指令则获取某一个键的值.不同的数据结构,Redis 有不同的指令,这样指令一共有几十个,下面主要介绍一些常用的指令. Redis 对 Key 也就是键有各种各样的指令,主要有下面的指令(下面的指令中小写字符串都是参数,可以自定义):>keys *  //返回键(key) >keys list*   //返回名以list开头的所有键(key)>exist

兄弟连学python(26) --- if not

python if not 判断是否为None的情况 if not x if x is None if not x is None if x is not None`是最好的写法,清晰,不会出现错误,以后坚持使用这种写法. 使用if not x这种写法的前提是:必须清楚x等于None, False, 空字符串"", 0, 空列表[], 空字典{}, 空元组()时对你的判断没有影响才行 ==============转载至http://blog.csdn.net/sasoritattoo/

兄弟连学Python(06)------- 条件语句和循环语句

Python的条件语句和循环语句的基础知识: 1.条件语句:包括单分支.双分支和多分支语句,if-elif-else 2.循环语句:while的使用及简单网络刷博器爬虫 3.循环语句:for的使用及遍历列表.元组.文件和字符串 在讲诉条件语句.循环语句和其他语句之前,先来补充语句块知识.(前面讲函数时已经用到过) 语句块并非一种语句,它是在条件为真(条件语句)时执行或执行多次(循环语句)的一组语句.在代码前放置空格或tab字符来缩进语句即可创建语句块.很多语言特殊单词或字符(如begin或{)来

兄弟连学python(1)——MySQL

MySQL官网:http://www.mysql.com MySQL是WEB应用方面最好的RDBMS应用软件之一 RDBMS:Relational Database Management System关系数据库管理系统 使用 UNION | UNION ALL 语法 UNION 用于合并多个查询的结果集,我目前遇到的主要有如下两个场景用起来比较有效: 1. 同表的复杂查询,很难通过一个 SELECT 语句搞定2. 多表查询,但返回的数据一致,常见一些聚合数据统计需求 UNION 也可以加 lim

兄弟连学python (01) ----表单的设计

简单的表单编辑:<!DOCTYPE HTML> <html lang='en'> <head> <meta chaset='utf-8'/> <title>from练习</title> </head> <body> <from> <table width='500px' height='700px' border='2' align='center'> <tr> <td

兄弟连学python (02) ----简易抽奖器

import tkinter import random import tkinter.messagebox class choujiang: def __init__(self): self.root=tkinter.Tk() self.root.minsize(400,400) self.root.resizable(width=False,height=False) self.root.title("简单抽奖器") self.result1 = tkinter.StringVar

在兄弟连学Python Python的数据类型

在Python中可以自定义的数据内容有无数种,但是系统默认的标准类型有六种: 一.Number 类型 分为四种类: Int 整型 Float 浮点型 Bool 布尔类型 String 字符串类型 字符串类型就是用引号括起来的文字类型: 每一种引号中都可以包含其他的俩中引号方式.也可以使用转义字符的方式 注: 转义字符: Complex 复数类型 二.List  列表类型 列表是一组有顺序的数据组合,且可修改.列表的标识符号为[ ] 例子:    list1 = [1,3,4,5,8] 三.Tup

兄弟连学Python ----Python函数

一.Python 函数的作用 函数是可以重复使用,能够实现特定功能的代码段是一种特定的代码组结构. 二.定义函数:   2.带有参数的函数格式: 三.函数的调用: 定义一个函数只是为函数起了一个名字,指定了代码的结构设置里功能, 想要使用这个函数可以直接书写函数的名字调用也可以 通过另一个函数执行 如下实例: 以上就是我函数的一些基本内容,关于函数的其他情况下一遍会有详细的 描述.