1. 什么是redis

    redis是一个nosql(not only sql不仅仅只有sql)数据库.翻译成中文叫做非关系型型数据库.

    关系型数据库:以二维表形式存储数据

    非关系型数据库: 以键值对形式存储数据(key, value形式)

    是一家意大利的创业公司出的,然后后来这家公司被VMware赞助. redis底层用C语句编写.

    

    redis是将数据存放到内存中,由于内容存取速度快所以redis被广泛应用在互联网项目中,

    redis有点:存取速度快,官方称读取速度会达到30万次每秒,写速度在10万次每秒最有,具体限制于硬件.

    缺点:对持久化支持不够良好,

    所以redis一般不作为数据的主数据库存储,一般配合传统的关系型数据库使用.

2. redis应用领域

    分布式缓存

    保存博客或者论坛的留言回复等.

    总之是用在数据量大,并发量高的情况下

    分布式session

(session数据存储在web server中,当使用集群时,多台机器无法共享session

      集群环境共享session的通用做法是存储在redis中)

    ServletContext

(

application对象 (ServletContext)-----可以存放全局对象---------------特点:tomcat启动后存在,直到服务器停止它才结束

           here is one context per "web application" per Java Virtual Machine

           如果是集群环境怎么办?

               放到数据库里面,性能存在问题?    

                       解决方案----------用内存数据库,如redis

提问?

     用静态变量存放PV是否可以?

          在单机环境,效果和ServletContext基本一致,但是在集群环境不行

)

    static

注:比如监听器、过滤器之类的单例对象,因为只是监听或者拦截一种对象或者状态,不记录数据,所有不需要存在redis中;同样request对象只是一次请求,这也是不需要的。

3. 怎么用

    redis主要就是使用命令来进行操作,java端在代码中可以使用Jedis来操作redis服务器

    redis数据类型

        字符串String

        列表list  redis中使用的是双向循环链表来实现的list,在redis中更像栈

        散列Hash  一般应用于将redis作为分布式缓存,存储数据库中的数据对象

        集合set set中数据是无序的并且不允许重复

        有序集合zset redis会根据分数自动排序,这里可以使用在学生成绩排序,

        或者是手机应用商店流行软件排名等需求中

4.redis持久化方案:

    rdb:可以设置间隔多长时间保存一次(Redis不用任何配置默认的持久化方案)

        优点:让redis的数据存取速度变快

        缺点:服务器断电时会丢失部分数据(数据的完整性得不到保证)

    aof:可以设置实时保存

        优点:持久化良好,能包装数据的完整性

        缺点:大大降低了redis系统的存取速度

5. 主从复制:

    这里使用了心跳检测机制,主从复制必须使用rdb持久化方式

    从服务器一般是只读的,保证主服务器和从服务器的数据一致性