redis注解使用 自定义注解redis缓存

redis和简单的map有什么区别大的方向,redis是内存数据库 , 独立进程;map是java的数据类型 redis支持五种数据类型:string,list,hash(字典),set(集合),zset(有序集合) 。
Redis 和 Java 中的 HashMap 是两个不同的东西,不能直接进行比较 。Redis 是一款基于内存的键值存储系统,支持多种数据结构,包括字符串、列表、哈希表、集合和有序集合等 。
Set和List都继承自Collection,而Map则和Collection没什么关系 。Set和List的区别在于Set不能重复 , 而List可以重复 。Map和Set与List的区别在于,Map是存取键值对,而另外两个则是保存一个元素 。
Map:适合储存键值对的数据 。Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点 , 还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征 。
一个是存储单列数据的集合 , 另外一个是存储键 和值 这样的双列数的集合,List中存储的数据是有顺序的,并且允许重复 。。Map中存储的数据是没有顺序的,其键是不能重复的,它的值是可以有重复的 。。
redis做mysql的缓存redis是一种内存性的数据存储服务,所以它的速度要比mysql快 。2,redis只支持String , hashmap , set,sortedset等基本数据类型,但是不支持联合查询 , 所以它适合做缓存 。
前者终究是个缓存,不可能永久保存数据(LRU机制) , 支持分布式,后者除了缓存的同时也支持把数据持久化到磁盘等,redis要自己去实现分布式缓存(貌似最新版本的已集成),自己去实现一致性hash 。
应用Redis实现数据的读写,同时利用队列处理器定时将数据写入mysql 。
【redis注解使用 自定义注解redis缓存】对于变化频率非常快的数据来说 , 如果还选择传统的静态缓存方式(Memocached、File System等)展示数据,可能在缓存的存取上会有很大的开销 , 并不能很好的满足需要,而Redis这样基于内存的NoSQL数据库,就非常适合担任实时数据的容器 。
脚本同步:自己写脚本将数据库数据写入到redis/memcached 。这就涉及到实时数据变更的问题(mysql row binlog的实时分析),binlog增量订阅Alibaba 的canal  , 以及缓存层数据 丢失/失效 后的数据同步恢复问题 。
redis是一个支持网络、可基于内存亦可持久化的日志型、Key-Value数据库 。可以认为redis比mysql简化很多 。mysql支持集群 。
面试中问到Redis持久化的原理,本篇在做详细解答1、可在redis.conf中配置 , 会以一段时间内达到指定修改的次数为规则来触发快照操作 , 快照文件名为dump.rdb 。每当Redis服务重启的时候都会从该文件中把数据加载到内存中 。在60秒内有10000次操作即触发RDB持久化 。
2、RDB 持久化机制 :是对 redis 数据执行周期性的持久化 。这种方式就是将内存中数据以快照的方式写入到二进制文件中 , 默认的文件名为 dump.rdb 。客户端也可以使用save或者bgsave命令通知redis做一次快照持久化 。
3、AOF(append only file)持久化:以独立日志的方式记录每次写命令,重启时再重新执行AOF文件中的命令达到恢复数据的目的 。AOF的主要作用是解决了数据持久化的实时性,目前已经是Redis持久化的主流方式 。
4、在redis的配置里有着这样的一段配置:save 900 1save 300 10save 60 10000很关键的一段配置 , 这时RDB持久化的核心 。
5、file(aof)里面(这称为“全持久化模式”) 。
谈谈redis,memcache的区别和具体应用场景1、数据一致性不同 redis使用的是单线程模型,保证了数据按顺序提交 。memcache需要使用cas保证数据一致性 。
2、应用场景:Redis sorted set的使用场景与set类似 , 区别是set不是自动有序的,而sorted set可以通过用户额外提供一个优先级(score)的参数来为成员排序,并且是插入有序的,即自动排序 。
3、Redis不可能比Memcache快 很多开发者都认为Redis不可能比Memcached快 , Memcached完全基于内存 , 而Redis具有持久化保存特性 , 即使是异步的,Redis也不可能比Memcached快 。但是测试结果基本是Redis占绝对优势 。
4、性能 都比较高,性能对我们来说应该都不是瓶颈 。总体来讲 , TPS 方面 redis 和 memcache 差不多,要大于 mongodb 。操作的便利性 memcache 数据结构单一 。
5、Memcached是以LiveJurnal旗下DangaInteractive公司的BardFitzpatric为首开发的高性能分布式内存缓存服务器 。其本质上就是一个内存key-value数据库,但是不支持数据的持久化,服务器关闭之后数据全部丢失 。
6、如果要说内存使用效率 , 使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached 。当然,这和你的应用场景和数据特性有关 。

    推荐阅读