Redis 学习

2018-08-22  本文已影响0人  梅小c

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作为缓存来使用的话,将数据存储到内存中,如果使用正常关闭,则会将内存数据持久化到本地之后,再关闭。

如果是强制关闭,则不会进行持久化操作,可能会造成部分数据的丢失。

上一篇下一篇

猜你喜欢

热点阅读