美文网首页
Redis 学习

Redis 学习

作者: 梅小c | 来源:发表于2018-08-22 22:17 被阅读0次

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

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

    相关文章

      网友评论

          本文标题:Redis 学习

          本文链接:https://www.haomeiwen.com/subject/wlduiftx.html