千锋教育-做有情怀、有良心、有品质的IT职业教育机构

400-811-9990
当前位置:千锋视频教程 >  python视频教程  >  Python学习之快速掌握Redis数据库的安装与操作

Python学习之快速掌握Redis数据库的安装与操作

时间:2018-06-01 13:25     来源:千锋视频教程 作者:千锋老师

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

NoSQL,泛指非关系型的数据库。随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题。

介绍

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

简介

================================================

redis是一个key-value存储系统。 和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。 这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。

*在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。 区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。 它提供了Python,Ruby,Erlang,PHP客户端,使用很方便。

安装:

方式一:

下载地址:http://redis.io/download,下载最新文档版本。

本教程使用的最新文档版本为 2.8.17,下载并安装:

$ wgethttp://download.redis.io/releases/redis-2.8.17.tar.gz

$ tar xzfredis-2.8.17.tar.gz

$ cd redis-2.8.17

$ make

make完后

redis-2.8.17目录下会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli,两个程序位于安装目录 src 目录下:

下面启动redis服务.

$ cd src

$ ./redis-server

注意这种方式启动redis

使用的是默认配置。也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动。

$ cd src

$ ./redis-serverredis.conf

redis.conf是一个默认的配置文件。我们可以根据需要使用自己的配置文件。

启动redis服务进程后,就可以使用测试客户端程序redis-cli和redis服务交互了。 比如:

$ cd src

$ ./redis-cli

redis> set foobar

OK

redis> get foo

"bar"

方式二:

在 Ubuntu 系统安装 Redi 可以使用以下命令:

$sudo apt-getupdate

$sudo apt-getinstall redis-server

启动 Redis

$ redis-server

查看 redis 是否启动?

$ redis-cli

* 以上命令将打开以下终端:

redis127.0.0.1:6379>

127.0.0.1 是本机 IP ,6379 是 redis 服务端口。现在我们输入 PING 命令。

redis127.0.0.1:6379> ping

PONG

基本操作

Redis的数据类型共计5种类型:

string(字符串)

hash(哈希表)

list(双向链表)

set(集合)

zset(有序集合)

1 String(子串类型)

set命令:设置一个键和值,键存在则只覆盖,返回ok

> set 键  值    例如: >set name zhangsan

get命令:获取一个键的值,返回值

> get 键        例如:>get name

setnx命令:设置一个不存在的键和值(防止覆盖),

> setnx 键值     若键已存在则返回0表示失败

setex命令:设置一个指定有效期的键和值(单位秒)

> setex 键 [有效时间] 值  例如: >setex color 10 red

不写有效时间则表示永久有效,等价于set

setrange命令:替换子字符串 (替换长度由子子串长度决定)

> setrange 键位置 子字串 

> setrange name 4 aa  将name键对应值的第4个位置开始替换

mset命令:批量设置键和值,成功则返回ok

> mset 键1 值1 键2 值2 键3 值3 ....

msetnx命令:批量设置不存在的键和值,成功则返回ok

> msetnx 键1 值1 键2 值2 键3 值3 ....

getset命令:获取原值,并设置新值

getrange命令:获取指定范围的值

>getrange 键 0,4     //获取指定0到4位置上的值

mget命令: 批量获取值

>mget 键1 键2 键3....

incr命令: 指定键的值做加加操作,返回加后的结果。

>  键       例如: >incr kid

incrby命令: 设置某个键加上指定值

> incrby 键 m    //其中m可以是正整数或负整数

decr命令: 指定键的值做减减操作,返回减后的结果。

> decr 键        例如: >decr kid

decrby命令: 设置某个键减上指定值

> decrby 键 m    //其中m可以是正整数或负整数

append命令:给指定key的字符串追加value,返回新字符串值的长度

>append 键追加字串

strlen求长度 >strlen 键名   //返回对应的值。

2 hashes类型

hset命令:设置一个哈希表的键和值

>hset hash名键  值

如:>hset user:001 name zhangsan

hsetnx命令:设置一个哈希表中不存在的键和值

>hsetnx hash名键  值  //成功返回1,失败返回0

如:>hsetnx user:001 name zhangsan

hmset命令: 批量设置

hget命令: 获取执行哈希名中的键对应值

>hexistsuser:001 name //是否存在, 若存在返回1

>hlenuser:001  //获取某哈希user001名中键的数量

>hdel user:001name //删除哈希user:001 中name键

>hkeysuser:002   //返回哈希名为user:002中的所有键。

>hvalsuser:002   //返回哈希名为user:002中的所有值。

>hgetalluser:002 //返回哈希名为user:002中的所有键和值。

3 hashes类型

hset命令:设置一个哈希表的键和值

>hset hash名键  值

如:>hset user:001 name zhangsan

hsetnx命令:设置一个哈希表中不存在的键和值

>hsetnx hash名键  值  //成功返回1,失败返回0

如:>hsetnx user:001 name zhangsan

hmset命令: 批量设置

hget命令: 获取执行哈希名中的键对应值

>hexistsuser:001 name //是否存在, 若存在返回1

>hlenuser:001  //获取某哈希user001名中键的数量

>hdel user:001name //删除哈希user:001 中name键

>hkeysuser:002   //返回哈希名为user:002中的所有键。

>hvalsuser:002   //返回哈希名为user:002中的所有值。

>hgetall user:002//返回哈希名为user:002中的所有键和值。

4. list类型(双向链表结构)

list即可以作为“栈”也可以作为"队列"。

操作:

>lpush list1 "world"  //在list1头部压入一个字串

>lpush list1 "hello"  // 在list1头部压入一个字串

>lrange list1 0 -1  //获取list1中内容

0:表示开头  -1表示结尾。

>rpush list2 "world"  //在list2尾部压入一个字串

>rpush list2 "hello"  // 在list2尾部压入一个字串

>lrange list2 0 -1  //获取list2中内容

0:表示开头  -1表示结尾。

>linsert list2 before "hello""there"

在key对应list的特定位置前或后添加字符串

>lset list2 1 "four"

修改指定索引位置上的值

>lrem list2 2 "hello"  //删除前两个hello值

>lrem list2 -2 "hello" //删除后两个hello值

>lrem list2 0 "hello"  //删除所有hello值

>ltrim mylist8 1 -1    //删除此范围外的值

>lpop list2   //从list2的头部删除元素,并返回删除元素

>rpop list2   //从list2的尾部删除元素,并返回删除元素

>rpoplpush list1 list2    //将list1的尾部一个元素移出到list2头部。并返回

>lindex list2 1 //返回list2中索引位置上的元素

>llen list2 //返回list2上长度

5 sets类型和操作

>sadd myset "hello" //向myset中添加一个元素

成功返回1,失败(重复)返回0

>smembers myset //获取myset中的所有元素

>srem myset "one" //从myset中删除一个one

成功返回1,失败(不存在)返回0

>spop myset //随机返回并删除myset中的一个元素

>sdiff myset1 myset2 //返回两个集合的差集

以myset1为标准,获取myset2中不存在的。

>sdiffstor

常用命令

键值相关命令

>keys * //返回键(key)

>keys list*   //返回名以list开头的所有键(key)

>exists list1  //判断键名为list1的是否存在

存在返回1, 不存在返回0

>del list1 //删除一个键(名为list1)

>expire list1 10 //设置键名为list1的过期时间为10秒后

>ttl list1 //查看键名为list1的过期时间,若为-1表示以过期

 

>move age 1 //将键名age的转移到1数据库中。

>select 1 //表示进入到1数据库中,默认在0数据库

>persist age //移除age的过期时间(设置为过期)

Redis高级实用特性

1. 安全性:为Redis添加密码

1.进入配置文件:

vi /usr/local/redis/etc/redis.conf

设置:requirepass redis的密码

2. 重启服务:

# ./redis-cli shutdown 执行关闭

# ./redis-server/usr/local/redis/etc/redis.conf  启动

3. 登录(两种)

# ./redis-cli 客户端命令链接服务器

>auth 密码值  //授权后方可使用

# ./redis-cli -a  密码 //连接时指定密码来进行授权

2. 主从复制

操作步骤:

1.先将linux虚拟机关闭,之后克隆一个。

2.启动两个虚拟机:master(主)和slave(从)

3. 在slave(从)中配置一下ip地址

# ifconfig eth0 192.168.128.229

# ping 一下看看通不通。

4. 配置从机

进入:配置文件

slaveof 192.168.128.228 6379   //配置连接主机的Redis的ip和端口

masterauth 密码  //配置连接密码

最后启动slave(从)机的Redis服务。

其他:可以通过info命令中的role属性查看自己角色是master、slave

3. 事务处理

>multi  //开启一个事务

>set age 10 //暂存指令队列

>set age 20

>exec   //开始执行(提交事务)

或>discard //清空指令队列(事务回滚)

4. 乐观锁

在事务前对被操作的属性做一个:

> watch age

>multi  //开启一个事务(在此期间有其他修改,则此处会失败)

>set age 10 //暂存指令队列

>set age 20

>exec   //开始执行(提交事务)

或>discard //清空指令队列(事务回滚)

5. 持久化机制(通过修改配置文件做设置)

snapshotting(快照)默认方式 配置 save save 900 1 #900秒内如果超过1个key被修改,则发起快照保存 save 300 10 #300秒内容如超过10个key被修改,则发起快照保存 save 60 10000

Append-onlyfileaof方式)配置 appendonly on 改为yes 会在bin目录下产生一个.aof的文件

关于aof的配置

appendonly yes //启用aof 持久化方式

appendfsync always//收到写命令就立即写入磁盘,最慢,但是保证完全的持久化

appendfsynceverysec //每秒钟写入磁盘一次,在性能和持久化方面做了很好的折中

appendfsync no //完全依赖os,性能最好,持久化没保证

6. 发布及订阅消息

需要开启多个会话端口

会话1:>subscribe tv1     //监听tv1频道

会话2:>subscribe tv1 tv2 //监听tv1和tv2频道

会话3: >publish tv1 消息   //向tv1频道发送一个消息

7. 使用虚拟内存

在redis配置文件中设置 vm-enabled yes #开启vm功能

vm-swap-file/tmp/redis.swap #交换出来的value保存的文件路径 vm-max-memory 1000000 #redis使用的最大内存上限

vm-page-size 32 #每个页面的大小32字节

vm-pages 134217728#最多使用多少页面

vm-max-threads 4 #用于执行value对象换入患处的工作线程数量

先将linux虚拟机关闭,之后克隆一个。

2.启动两个虚拟机:master(主)和slave(从)

3. 在slave(从)中配置一下ip地址

# ifconfig eth0 192.168.128.229

# ping 一下看看通不通。

4. 配置从机

进入:配置文件

slaveof 192.168.128.228 6379   //配置连接主机的Redis的ip和端口

masterauth 密码  //配置连接密码

最后启动slave(从)机的Redis服务。

其他:可以通过info命令中的role属性查看自己角色是master、slave

千锋Python培训课程还有严格、科学、负责的教学就业管理制度,班主任、职业规划师全程跟班,把握每位学员的学习状态,并有专业的职业素养课和就业指导课,确保教学及就业质量。还有大量的免费Python视频教程帮助学员快速学习,更可以免费加入千锋开发者联盟,为会员提供免费技术支持及终身就业服务,免费参加千锋举办的各类技术沙龙和活动!

  • 北京天丰利校区(总部)地址:北京市海淀区宝盛北里西区28号天丰利商城4层
    北京沙河校区:北京市昌平区沙阳路18号北京科技职业技术学院广场服务楼2、3层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 深圳西部硅谷校区地址:深圳市宝安区宝安大道5010号深圳西部硅谷B座A区605-619
    深圳大学城校区地址:深圳市南山区留仙大道1201号大学城创客小镇16栋3楼
    咨询电话: 0755-23015275/23015546-801(硅谷) 0755-86660670-801(大学城)
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 上海校区地址:上海市宝山区同济支路199号智慧七立方3号楼2-4层
    咨询电话:400-811-9990 021-65233829-609
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 郑州校区地址:郑州市二七区航海中路60号海为科技园C区10层、12层
    咨询电话:0371-55191750
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 广州校区地址:广州市天河区元岗路310号智汇park创意园E座5层
    咨询电话:020-22119207
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 大连校区地址:辽宁省大连市高新园区爱贤街10号大连设计城A座901
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 武汉金融港校区地址:武汉市东湖高新技术开发区光谷大道77号金融港B18栋3楼
    武汉智慧园校区地址:武汉市东湖高新技术开发区光谷大道61号智慧园21栋2楼
    咨询电话:027-59313371
    面授课程:HTML5大前端培训、全链路UI/UE设计培训、PHP全栈+服务器集群培训、JavaEE+分布式开发培训、大数据+人工智能培训、 Unity游戏开发培训、Python培训、云计算+信息安全培训、全栈软件测试培训、智能物联网+嵌入式培训、Android培训、iOS培训
  • 成都校区地址:成都市武侯区科华北路62号力宝大厦N(北楼)18楼
    咨询电话:400-811-9990 028-83178771
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 西安校区地址:西安市雁塔区高新六路52号立人科技C座西区4楼
    咨询电话:029-85363390
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 杭州校区地址:浙江省杭州市江干区九堡旺田书画城A座4层
    咨询电话:400-811-9990 0571-86893632
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 青岛校区地址:青岛市市北区龙城路卓越世纪中心3号楼8层801
    咨询电话:0532-80911190
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 重庆校区地址:重庆市高新区科园一路2号大西洋国际12-1
    咨询电话:400-811-9990 023-68883009
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 长沙校区地址:湖南省长沙市岳麓区麓谷企业广场A2栋三单元306号
    咨询电话:0731-85513210
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 哈尔滨校区地址:哈尔滨市松北区创新一路699号 科技创新城19号楼B座五楼
    咨询电话:400-811-9990/0451-87173191
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 南京校区地址:南京市建邺区应天大街780号应天智汇产业园弘辉园1幢2楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、物联网+嵌入式培训、大数据+人工智能培训、全栈软件测试培训、PHP全栈+服务器集群培训、云计算+信息安全培训、Unity游戏开发培训、红帽RHCE认证、Android培训、iOS培训、好程序员
  • 千锋教育服务号

    了解千锋动态
    关注千锋教育服务号

  • 千锋教育移动站

    扫一扫快速进入
    千锋移动端页面

  • 千锋互联服务号

    扫码匿名提建议
    直达CEO信箱