Redis数据库
nosql 介绍
目标
- 了解nosql概念
- 了解Redis的概念
- 了解Redis的特点
nosql介绍
NoSQL:一类新出现的数据库(not only sql),它的特点:
- 不支持SQL语法
- 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
- NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
- NoSQL中的产品种类相当多:
- Mongodb
- Redis
- Hbase hadoop
- Cassandra hadoop
 
NoSQL和SQL数据库的比较:
- 适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
- “事务”特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
- 两者在不断地取长补短,呈现融合趋势
Redis简介
- Redis是一个开源的使用ANSI
 C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
- Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
Redis特性
- Redis 与其他 key - value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
Redis 优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
redis应用场景
- 用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
- 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
- 在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
- 只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….
推荐阅读
Redis 环境搭建
学习目标
- 了解Redis环境搭建
下载
- 
当前redis最新版本是4.0,它是一个测试版本,稳定版本是3.2版本。 
- 
当前ubuntu虚拟机中已经安装好了redis,以下步骤可以跳过 
 最新稳定版本下载链接:http://download.redis.io/releases/redis-3.2.8.tar.gz
- 
step1:下载 
- 
step2:解压 tar -zxvf redis-3.2.8.tar.gz 
- 
step3:复制,放到usr/local⽬录下 sudo mv ./redis-3.2.8 /usr/local/redis/ 
- 
step4:进⼊redis⽬录 cd /usr/local/redis/ 
- 
step5:生成 sudo make 
- 
step6:测试,这段运⾏时间会较⻓ sudo make test 
- 
step7:安装,将redis的命令安装到/usr/local/bin/⽬录 sudo make install 
- 
step8:安装完成后,我们进入目录/usr/local/bin中查看 cd /usr/local/binls -all redis-server redis服务器redis-cli redis命令行客户端redis-benchmark redis性能测试工具redis-check-aof AOF文件修复工具redis-check-rdb RDB文件检索工具 
- 
step9:配置⽂件,移动到/etc/⽬录下 
- 
配置⽂件⽬录为/usr/local/redis/redis.conf sudo cp /usr/local/redis/redis.conf /etc/redis/ 
虚拟环境redis安装
安装包
安装Redis的有3种方式https://github.com/andymccurdy/redis-py
- 
第一种:进⼊虚拟环境py_django,联⽹安装包redis pip install redis 
- 
第二种:进⼊虚拟环境py_django,联⽹安装包redis easy_install redis 
- 
第三种:到中⽂官⽹-客户端下载redis包的源码,使⽤源码安装 一步步执行 
 wget https://github.com/andymccurdy/redis-py/archive/master.zipunzip master.zipcd redis-py-mastersudo python setup.py install
调⽤模块
- 
引⼊模块 from redis import * 
- 
这个模块中提供了StrictRedis对象(Strict严格),⽤于连接redis服务器,并按照不同类型提供 了不同⽅法,进⾏交互操作 
Redis的配置
配置
- 
Redis的配置信息在/etc/redis/redis.conf下。 
- 
查看 sudo vi /etc/redis/redis.conf 
核心配置选项
- 
绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip bind 127.0.0.1 
- 
端⼝,默认为6379 port 6379 
- 
是否以守护进程运⾏ - 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
- 如果以⾮守护进程运⾏,则当前终端被阻塞
- 设置为yes表示守护进程,设置为no表示⾮守护进程
- 推荐设置为yes
 daemonize yes 
- 
数据⽂件 dbfilename dump.rdb 
- 
数据⽂件存储路径 dir /var/lib/redis 
- 
⽇志⽂件 logfile /var/log/redis/redis-server.log 
- 
数据库,默认有16个 database 16 
- 
主从复制,类似于双机备份。 slaveof 
参考资料
redis配置信息http://blog.csdn.net/ljphilp/article/details/52934933
Redis服务器端和客户端的命令
服务器端
- 
服务器端的命令为redis-server 
- 
可以使⽤help查看帮助⽂档 redis-server --help 
- 
推荐使⽤服务的⽅式管理redis服务 
- 
启动 sudo service redis start 
- 
停⽌ sudo service redis stop 
- 
重启 
 sudo service redis restart
- 
个人习惯 ps -ef|grep redis 查看redis服务器进程sudo kill -9 pid 杀死redis服务器sudo redis-server /etc/redis/redis.conf 指定加载的配置文件 
客户端
- 客户端的命令为redis-cli
- 可以使⽤help查看帮助⽂档
redis-cli --help 
- 连接redis
redis-cli 
- 运⾏测试命令
ping 
- 切换数据库
- 数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库
select n 
Redis存储数据结构
数据结构
- redis是key-value的数据结构,每条数据都是⼀个键值对
- 键的类型是字符串
- 注意:键不能重复

- 值的类型分为五种:
- 字符串string
- 哈希hash
- 列表list
- 集合set
- 有序集合zset
 
数据操作行为
- 保存
- 修改
- 获取
- 删除
点击中⽂官⽹查看命令⽂档http://redis.cn/commands.html

 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号