Redis
什么是NoSQL
NoSQL:(Not Only SQL)不仅仅是SQL
泛指非关系型数据库,随着web2.0互联网的诞生!传统的关系型数据库很难对付web2.0时代!尤其是超大规模的高并发社区!暴露出来很多难以克服的问题,NoSQL在当下大数据环境的发展十分迅速,Redis是发展最快的,是必须要掌握的技术
很多的数据类型用户的个人信息,社交网络,地理位置。这些数据类型的存储不需要一个固定的格式,不需要多余的操作就可以横向扩展
NoSQL特点
解藕
1、方便扩展(数据之间没有关系,很好扩展)
2、大数据量高性能(Redis每秒可以读取11万次,写8万次,NoSQL的缓存记录级,是一种细粒度的缓存,性能会比较高)
3、数据类型丰富(不需要事先设计数据库!如果是数据库量十分大的表,很多人就无法设计了)
4、传统RDBMS和NoSQL
传统的RDBMS
- 结构化组织
- SQL
- 数据和关系都存在单独的表中
- 操作操作,数据定义语言
- 严格的一致性
- 基础的事物
- 。。。。。
NoSQL
- 不仅仅是数据
- 没有固定的查询语言
- 键值对存储,列存储,文档存储,图形数据库(社交关系)
- 最终一致性
- CAP定理 和 BASE理论(异地多活)
- 保证高性能、高可用、高可扩展
- 。。。。
了解:3V+3高
大数据时代的3V:主要是描述问题的
- 海量Volume
- 多样Variety
- 实时Velocity
大数据时代的3高:对程序的要求
- 高并发
- 高可扩(随时可以水平扩展,增加服务器)
- 高性能(保证用户体验和性能)
真正在公司的实践:NoSQL + RDBMS一起使用才是最强的
NoSQL四大分类
KV键值对:
- 新浪:Redis
- 美团:Redis + Tair
- 阿里、百度:Redis + mamecache
文档型数据库(bson格式和json一样):
- MongoDB(一般必须掌握)
- MongoDB是一个基于分布式文件存储的数据库,C++编写,主要用来处理大量的文档
- MongoDB是一个介于关系型数据库和非关系型数据库中间的产品,是NoSQL中功能最丰富,最像关系型数据库的
列存储数据库
- HBase
- 分布式文件系统
图关系数据库
- 拓扑图,存放的是关系,比如:朋友圈社交网络,广告推荐
- Neo4j,InfoGrid
分类 | Examples举例 | 典型应用场景 | 数据模型 | 优点 | 缺点 |
---|---|---|---|---|---|
键值对(key-value) | Tokyo Cabinet/Tyrant, Redis, Voldemort, Oracle BDB | 内容缓存,主要用于处理大量数据的高访问负载,也用于一些日志系统等等。 | Key 指向 Value 的键值对,通常用hash table来实现 | 查找速度快 | 数据无结构化,通常只被当作字符串或者二进制数据 |
列存储数据库 | Cassandra, HBase, Riak | 分布式的文件系统 | 以列簇式存储,将同一列数据存在一起 | 查找速度快,可扩展性强,更容易进行分布式扩展 | 功能相对局限 |
文档型数据库 | CouchDB, MongoDb | Web应用(与Key-Value类似,Value是结构化的,不同的是数据库能够了解Value的内容) | Key-Value对应的键值对,Value为结构化数据 | 数据结构要求不严格,表结构可变,不需要像关系型数据库一样需要预先定义表结构 | 查询性能不高,而且缺乏统一的查询语法。 |
图形(Graph)数据库 | Neo4J, InfoGrid, Infinite Graph | 社交网络,推荐系统等。专注于构建关系图谱 | 图结构 | 利用图结构相关算法。比如最短路径寻址,N度关系查找等 | 很多时候需要对整个图做计算才能得出需要的信息,而且这种结构不太好做分布式的集群 |
Redis入门
概述
Redis是什么
Redis(Remote Dictionary Server) 远程字典服务
即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
免费和开源!是当下最热门的NoSQL技术之一!也被人们称为结构数据库!
Redis能干嘛
- 内存存储、持久化,内存是断电即失的,所以说持久化很重要(RDB、AOF)
- 效率高,可以用于高速缓存
- 发布订阅系统
- 地图信息分析
- 计时器、计数器(浏览量!)
- 。。。。。
特性
-
多样的数据类型
-
持久化
-
集群
-
事物
。。。。。
学习中需要用到的东西
- Redis官网https://redis.io/
- Redis中文网http:/www./redis.cn/
- 下载地址:通过官网下载(Windows版本在Github上下载)
Redis一般都是安装在Linux系统上的,我们基于Linux学习
Windows安装
下载地址:https://github.com/dmajkic/redis
-
解压安装包
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gwKQiJTg-1627309557061)(/Users/mac/Documents/Typora/图片/Redis学习笔记/20200820103922318.png)]
-
开启redis-server.exe
-
启动redis-cli.exe测试
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iwKuu95P-1627309557065)(/Users/mac/Documents/Typora/图片/Redis学习笔记/20200820103950934.png)]
Linux安装
-
下载安装包!
redis-5.0.8.tar.gz
-
解压Redis的安装包!程序一般放在
/opt
目录下 -
基本环境安装
yum install gcc-c++ # 然后进入redis目录下执行 make # 然后执行 make install
使用的是5.0.8版本,高版本会有错误
-
redis默认安装路径
/usr/local/bin
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YRmHzdzW-1627309557069)(/Users/mac/Documents/Typora/图片/Redis学习笔记/96E862A5D66FD1132E309DA0970E7569.jpg)]
-
将redis的配置文件复制到 程序安装目录
/usr/local/bin/redisconfig
下,以后使用这个配置文件启动 -
redis默认不是后台启动,需要修改配置文件
修改配置文件中的
daemonize
将原来的no改为yes即可 -
通过制定的配置文件启动redis服务
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FCJKAu1S-1627309557072)(/Users/mac/Documents/Typora/图片/Redis学习笔记/20200820104228556.png)]
-
使用
redis-cli
测试连接[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qQaKkdjK-1627309557073)(/Users/mac/Documents/Typora/图片/Redis学习笔记/06E959754F9A3863A705CCD5054F4C29.jpg)]
-
查看redis的进程是否开启
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IYAqxRK9-1627309557076)(/Users/mac/Documents/Typora/图片/Redis学习笔记/21CC6A67CE34E492314AA3618E88A541.jpg)]
-
关闭Redis服务
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ujWQhPMM-1627309557078)(/Users/mac/Documents/Typora/图片/Redis学习笔记/03921D10-A4DC-4D2F-B7AF-207679CAE22F.png)]
-
再次查看进程是否存在
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uGi6JsFy-1627309557080)(/Users/mac/Documents/Typora/图片/Redis学习笔记/58EEEAEC-86C3-44BE-A38F-09B8DA338360.png)]
可以发现客户端进程已经结束,只剩下了redis的服务