`
dou_shini8820
  • 浏览: 80758 次
社区版块
存档分类
最新评论

Redis作为缓存自我总结

 
阅读更多

redis缓存服务器笔记
redis是一个高性能的key-value存储系统,能够作为缓存框架和队列
但是由于他是一个内存内存系统,这些数据还是要存储到数据库中的


作为缓存框架:
create/updae/delete---同时存到redis和数据库
query--先从redis查,没有记录才从数据库查,并把从数据库查的结果也放一份到redis

作为缓存队列:

2、把对象Object存储到redis中,怎么存?memcache存取对象是序列化和反序列化
使用通用的序列化、反序列化(频繁的会很消耗cpu,使用Google Protocol Buffer,将对象打成二

进制流)
或者使用json存储(阿里巴巴的fast-json)

3、java使用redis的客户端一般是:jedis
jedis的原生接口只支持基本数据类型和String、byte[]

4、我对redis队列的理解:
重要的数据:先存到数据库,然后存到redis
要求响应速度很高的的数据:先写缓存,然后通过消息队列再写入数据库

 因为Redis的value支持String、list、set、zset
那么就可以把redis的list当作队列来用
入队:lpush mylist 'hello1'
出队:lpop mylist

 

5、其提供AOF(追加式操作记录文件)和DUMP(定期数据备份)两种持久化方式

 

6、VM(虚拟内存机制):如果有1万条数据保存到内存中,那么我就要配置能存储这么多数据的内存
然后这1万条数据有9000条不是活跃数据,那就白白浪费了,可以这样做,当数据容量超过内存时,

将部分value存储到文件中
memcached是把数据完全存储到内存中,而redis是大部分的,因为他支持自定义的VM
同时Redis支持主从复制机制

0
0
分享到:
评论

相关推荐

    2022年java实训报告范文(计算机实训报告总结1000字).docx

    项目采用SpringBoot框架,结合Swagger2进行界面展示,Redis作为缓存系统,WebService处理信息调用,Mybatis作为数据持久化层,GitLab作为版本控制工具。我负责的部分包括用户订单查询、内部/外部通道号查询、订单...

    知识点汇总.rar

    【标题】"知识点汇总.rar" 是一个压缩包文件,其中包含了作者自我总结的关于Shell脚本的知识点。这个资源可能是作者个人学习和实践过程中的笔记,旨在帮助他人理解和掌握Shell脚本编程的基础与进阶技巧。 【描述】...

    Java面试题项目汇总.doc

    Spring提供了依赖注入和面向切面编程的能力,Spring MVC处理Web请求,MyBatis作为持久层框架简化了数据库操作,而Redis则用于缓存,提升了系统的响应速度。 3. **缓存策略**: 在所有项目中,你都负责将关键数据如...

    java简历项目_java简历.docx

    项目特色包括分布式系统架构,利用dubbo实现子系统间通信,使用redis做缓存并实现session共享,以提高系统性能。同时,使用solr作为搜索引擎,提供高效的搜索功能。王豪在该项目中负责了搜索模块、单点登录模块、...

    JAVA真实包装项目经验-在线教育项目面试

    - **Redis**:作为内存数据库,用于缓存高频访问的数据,提高系统性能。 - **MongoDB**:面向文档的NoSQL数据库,适用于存储大量松散结构的数据。 6. **操作系统**: - **Linux**:熟悉基本的命令行操作,是开发...

    深圳大数据行业java高级工程师岗位介绍JD模板.docx

    Oracle数据库系统用于存储海量数据,而Redis则作为高速缓存系统,提升数据读取效率。Spring和SpringBoot是广泛使用的Java开发框架,简化了应用开发和部署。Spring Cloud则提供了微服务架构的支持。MySQL和Oracle是...

    JAVA真实包装项目经验-二手车项目面试

    - 相关技术:Redis缓存、MongoDB数据库、RocketMQ消息队列、Nginx、Elasticsearch、Freemarker模板引擎、Docker容器化、Jenkins持续集成/持续部署(CI/CD)。 - 其他技术:阿里云OSS对象存储、Quartz定时任务。 ###...

    基于java Web的心理健康在线测评系统

    3.3 Redis:缓存常用数据,减轻数据库压力,提高系统性能。 3.4 Docker与Kubernetes:通过容器化部署,实现系统的快速部署和扩展。 四、系统开发流程 4.1 需求分析:明确系统功能需求,制定项目计划。 4.2 设计...

    Java秒杀系统方案优化 高性能高并发实战

    - **Redis**:作为高速缓存存储库存信息及其他静态数据,减轻数据库负担。 - **实现细节**:使用Redis原子操作(如`decr`)更新库存,避免竞态条件导致超卖问题。 3. **限流策略**: - **目的**:防止过多请求...

    TD案例总结

    - **缓存策略**:利用缓存减少对数据库的直接访问,如使用Redis或Memcached等缓存技术。 ### 案例二:微服务架构设计 随着业务复杂度的增加,传统的单体应用逐渐暴露出可维护性差、扩展困难等问题。微服务架构...

    3114006172陈世强数据库课程设计报告

    - **后端技术:** 使用Apache Maven进行项目构建管理,SpringMVC作为MVC框架,MyBatis作为持久层框架处理数据库交互,Redis作为缓存解决方案,Dubbo实现微服务间的RPC调用,Apache Zookeeper提供分布式协调服务,...

    Java开发工程师简历模板(三十九)

    【Java开发工程师简历模板分析】 本简历展示了Java开发工程师张三的专业...总结起来,这份简历揭示了张三作为一名Java开发工程师所掌握的技术栈、项目经验和职业素养,展示了他的全面技能和适应不同项目需求的能力。

    基于SpringBoot的博客系统设计与实现.pdf

    为了提升系统性能,可能采用缓存技术(如Redis),对高访问量数据进行缓存,减少数据库压力。同时,可以通过负载均衡和集群部署,保证在高并发情况下的系统稳定运行。 总结,基于SpringBoot的博客系统设计与实现是...

    高级资深java工程师岗位职责.docx

    3. 缓存中间件:深入理解Redis和Memcached等缓存技术,能有效提升系统的响应速度和数据处理能力。具备分布式缓存设计经验的工程师可以优化数据访问性能,减少数据库压力。 4. 前端开发技术:掌握React、Vue、...

    musical.ly微服务化之路 current.pdf

    - 引入Spring Boot和Spring Cloud:实现服务的自我发现(Eureka)、声明式远程调用(Feign+Ribbon)、断路器模式(Hystrix)、API网关(Zuul)、配置中心(Spring Cloud Config)、实时指标监控(Turbine+Hystrix ...

    大气通用Word简历模板(IT类)

    8. **功能重构**:张三负责了多次功能重构,例如采用Redis进行静态数据存储和内存数据实时更新,利用Redis的pub/sub功能,这反映了他对缓存系统和实时通信机制的掌握。 9. **项目经验**:在某汽车品牌4S店保养管理...

    研究

    在校期间曾参与一个企业命题的项目,这个项目主要使用了SpringBoot,SpringMVC,MyBatis和Spring Security框架,采用MySQL作为主要数据库,使用Redis由一个数据缓存,我在其中主要担任了一个负责人的角色,在负责...

    基于JFinal框架的个人博客系统

    9. **性能优化**:使用缓存技术,如Redis,减少数据库查询压力;使用GZIP压缩,减小网络传输的数据量。 **开发与部署** 开发过程中,可以使用Git进行版本控制,Maven或Gradle管理依赖,IntelliJ IDEA作为开发工具...

Global site tag (gtag.js) - Google Analytics