栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

redis学习笔记

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

redis学习笔记

redis学习

参考教程:【尚硅谷】Redis 6 入门到精通 超详细 教程_哔哩哔哩_bilibili

NoSql

redis是一种NoSql数据库,为了解决性能的问题

解决cpu和内存的压力,如图

session存储问题

    存储到客户端的cookie中,不安全存储到每台服务器上,数据冗余,session复制

解决io压力

NoSql(not only sql):非关系型数据库,不依赖业务逻辑方式存储,以简单的key-value模式存储,大大增加了数据库的扩展能力。(mysql是关系型数据库)

    不支持SQL标准不支持ACID(没有事务的四大特性:原子性、一致性、隔离性、持久性)远超SQL的性能

适用场景

    对数据高并发读写海量数据读写对数据高扩展性

不适用场景

    需要事务支持基于SQL的结构化查询存储,处理复杂的关系,需要即席查询
Redis

redis支持多数据类型,支持持久化,单线程+多路IO复用

redis5大数据类型:Redis字符串(String)、Redis列表(List)、Redis集合(Set)、Redis哈希(Hash)、Redis有序集合Zset

使用usr/local/bin/redis-cli连接redis

字符串String类型最大512M,自动扩容类似ArrayListList类型底层是双向列表Set是string类型的无序集合,底层是一个value为null的hash表,数据结构是dict字典,字典是哈希表实现哈希类型是键值对集合,他的value是一个string类型的field-value映射表,类似Java中的Map,哈希类型类似Java中的Map>有序集合Zset每个成员关联一个score,根据score有序

redis事务

Redis事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

Redis事务的主要作用就是串联多个命令防止别的命令插队。

悲观锁:每次拿数据都认为别人会修改,所以每次拿数据都会上锁,别人拿数据就会block阻塞直到拿到锁,传统关系型数据库很多地方用到这个锁机制,比如行锁、表锁、读锁、写锁,做操作之前都会上锁。

乐观锁:拿数据时很乐观,不会认为别人会修改,不会上锁,但是更新的时候会判断期间有没有别人更新该数据,可以使用版本号等机制,乐观锁适用于多读的场景,可以提高吞吐量。Redis就是利用这种check-and-set机制实现事务的。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/727591.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号