Redis 学习
1 Redis 介绍
1.1 什么是NoSql
为了解决高并发、高可用、高可扩展,大数据存储等一系列问题而产生的数据库解决方案,就是NoSql。NoSql,叫非关系型数据库,它的全名Not only sql。它不能替代关系型数据库,只能作为关系型数据库的一个良好补充。
1.2 NoSql的分类
键值(Key-Value)存储数据库
相关产品:Tokyo Cabinet/Tyrant、Redis、Voldemort、Berkeley DB
典型应用:内容缓存,主要用于处理大量数据的高访问负载。
数据模型:一系列键值对
优势:快速查询
劣势:存储的数据缺少结构化
列存储数据库
相关产品:Cassandra, HBase, Riak
典型应用:分布式的文件系统
数据模型:以列簇式存储,将同一列数据存在一起
优势:查找速度快,可扩展性强,更容易进行分布式扩展
劣势:功能相对局限
文档型数据库
相关产品:CouchDB、MongoDB
典型应用:Web应用(与Key-Value类似,Value是结构化的)
数据模型:一系列键值对
优势:数据结构要求不严格
劣势:查询性能不高,而且缺乏统一的查询语法
图形(Graph)数据库
相关数据库:Neo4J、InfoGrid、Infinite Graph
典型应用:社交网络
数据模型:图结构
优势:利用图结构相关算法。
劣势:需要对整个图做计算才能得出结果,不容易做分布式的集群方案。
1.3 什么是Redis
优点:速度快(底层使用的是内存,内存的存取速度远远高于硬盘存储,官方宣城10w的ops读取),持久化(提供了两种持久化的操作rdb与aof),支持多种数据结构(string,set,list(arraylist),hash(hashtable),zset),主从复制,高可用,分布式集群;丰富的功能(消息队列(set),作为缓存,发布与订阅)
Redis是使用c语言开发的一个高性能键值数据库。Redis可以通过一些键值类型来存储数据。
键值类型:String字符类型,map散列类型,list列表类型,set集合类型,sortedset有序集合类型
1.4 redis 的应用场景
缓存(数据查询、短连接、新闻内容、商品内容等等)。(最多使用)
分布式集群架构中的session分离。
聊天室的在线好友列表。
任务队列。(秒杀、抢购、12306等等)
应用排行榜。
网站访问统计。
数据过期处理(可以精确到毫秒)
2 redis的安装
2.1 redis 安装
第一步:安装vmware,并且在VMware中安装centos系统;
第二步:将redis的压缩包,上传到linux系统上
通过SSH工具进行传输,遇到无法传输的情况如:ssh encountered 1 errors during the transfer
解决方法有:三种法一:在SSH Secure File Transfer(上传文件那个),打开“Operation”菜单,打开“File Transfer Mode”子菜单,再选择“Binary”,OK!
法二:把服务器上同名文件删掉再传
法三:如果文件在桌面上,将要上传的文件复制到其它分区,再上传!
第三步:对redis的压缩包进行解压缩
tar -zxf redis-3.0.0.tar.gz
第四步:安装c语言环境:yum install gcc-c++
第五步:编译redis源码: cd redis-3.0.0
make(若linux中没有按照,则执行命令进行安装:yum -yinstallgcc automake autoconf libtool make)
第六步:安装redis:make install PREFIX=/usr/local/redis
第七步:查看是否安装成功:ll
2.2 redis 启动
2.2.1 前端启动
进入安装到的redis目录:进入bin目录中,执行 ./redis-server
关闭:Ctrl + c or ./redis-cli shutdown
2.2.2 后端启动
第一步:需要将redis解压之后的源码包中的redis.conf文件拷贝到bin目录下
[root@itheima bin]# cp /root/redis-3.0.0/redis.conf ./
第二步:修改redis.conf文件,将daemonize改为yes
先要使用vim redis.conf
第三步:使用命令后端启动redis
[root@itheima bin]# ./redis-server redis.conf
第四步:查看是否启动成功
关闭后端启动的方式:
强制关闭:[root@itheima bin]# kill -9 5071
正常关闭:[root@itheima bin]# ./redis-cli shutdown
在项目中,建议使用正常关闭。
因为redis作为缓存来使用的话,将数据存储到内存中,如果使用正常关闭,则会将内存数据持久化到本地之后,再关闭。
如果是强制关闭,则不会进行持久化操作,可能会造成部分数据的丢失。