问题的抛出
出现的问题
- 海量数据
- 高并发
罪魁祸首
- 性能瓶颈:磁盘IO性能低下
- 扩展瓶颈:数据关系复杂,扩展性差,不便于大规模集群
解决思路
- 降低磁盘IO次数,越低越好 —— 内存存储
- 去除数据间的关系,越简单越好 —— 不存储关系,仅存储数据
NoSQL简介
NoSQL:
即 Not-Only SQL( 泛指非关系型的数据库),作为关系型数据库的补充。
作用:
应对基于海量用户和海量数据前提下的数据处理问题。
特征:
- 可扩容,可伸缩
- 大数据量下得高性能
- 灵活得数据模型
- 高可用
常见Nosql数据库:
- Redis
- memcache
- HBase
- MongoDB
不同nosql有不同的应用场景,如:电商场景
Redis
概念:
Redis (REmote DIctionary Server)
是用 C 语言开发的一个开源的高性能键值对(key-value
)数据库。
特征:
-
数据间没有必然的关联关系
-
内部采用单线程机制进行工作
-
高性能。官方提供测试数据,50个并发执行100000 个请求,读的速度是110000 次/s,写的速度是81000次/s。
-
多数据类型支持
- 字符串类型 string - 列表类型 list - 散列类型 hash - 集合类型 set - 有序集合类型 sorted_set
-
持久化支持。可以进行数据灾难恢复
Redis应用
- 为热点数据加速查询(主要场景),如热点商品、热点新闻、热点资讯、推广类等高访问量信息等
- 任务队列,如秒杀、抢购、购票排队等
- 即时信息查询,如各位排行榜、各类网站访问统计、公交到站信息、在线人数信息(聊天室、网站)、设备信号等
- 时效性信息控制,如验证码控制、投票控制等
- 分布式数据共享,如分布式集群架构中的 session 分离
- 消息队列
- 分布式锁
Redis的基本操作
命令行模式工具使用思考
- 功能性命令
- 清除屏幕信息
- 帮助信息查阅
- 退出指令
信息添加
- 功能:设置key,value数据
- 命令
set key value 例:set name xiaobai
信息查询
- 功能:根据key查询对应的value,如果不存在,返回空(nil)
- 命令
get key 例:get name 输出 ===> xiaobai
清除屏幕信息
- 功能:清除屏幕中的信息
- 命令
clear
帮助命令
- 功能:获取命令帮助文档,获取组中所有命令信息名称
- 命令
help 命令名称 help @组名
推出客户端命令行模式
- 功能:推出客户端
- 命令
quit exit < ESC> 按键(慎用,除非用cmd打开的redis-cli,不然一按,就直接退出了)