Redis
1 Nosql概述
1.1 为什么要用Nosql
大数据时代(用户的个人信息,社交网络,地理位置,用户自己产生的数据,用户日志等等爆发增长!)
这时候就需要使用
NoSQL
数据库,NoSQL
可以很好的处理以上情况!
NoSQL
= Not Only SQL
(不仅仅是SQL
)
泛指非关系型数据库,随着web2.0互联网的诞生!传统的关系型数据库很难应付web2.0时代,尤其是超大规模的高并发的社区,暴露出来很多难以克服的问题,NoSQL
在当今大数据环境下发展的非常迅速,Redis
是发展最快。
很多的数据类型用户的个人信息,社交网络,地理位置,这些数据类型的存储不需要一个固定的格式,不需要多余的操作就可以横向扩展! 大部分是使用Map<String, Object>
键值对来控制!
1.2 NoSQL特点
解耦
- 方便扩展(数据之间没有关系,很好扩展!)
- 大数据高性能(Redis一秒写8w次,读11w,NoSQL的缓存记录级,是一种细粒度的缓存,性能会比较高)
- 数据类型是多样型的!(不需要事先设计数据库!随取随用!如果是数据量十分大的表,很多人就无法设计了)
- 传统RDBMS和NoSQL
传统的RDBMS
- 结构化组织
- SQL
- 数据和关系都存在单独的表中
- 操作操作,数据定义语言
- 严格的一致性
- 基础的事务
。。。
NoSQL
- 不仅仅是数据
- 没有固定的查询语言
- 键值对存储,列存储,文档存储,图形数据库(社交关系)
- 最终一致性
- CAP定理和BASE
- 高性能,高可用,高可扩
1.3 NoSQL的四大分类
KV键值对
- 新浪:Redis
- 美团:Redis + Tair
- 阿里百度:Redis + memecache
文档型数据库(bson格式 )
- MongoDB(一般必须要掌握)
- MongoDB是一个基于分布式文件存储的数据库,c++编写,主要用来处理大量的文档。
- MongoDB是一个介于关系型数据库和非关系型数据库中间的产品。
- ConthDB
列存储数据库
- HBase
- 分布式文件系统
图关系数据库
- 不是存储图形,而是存储关系的,比如:朋友圈社交网络,广告推荐
- Neo4j 、InfoGrid
2 Redis入门
2.1 windows安装
https://github.com/tporadowski/redis/releases
解压即可
默认端口号:6379
配置环境变量到path
启动:双击redis-server.exe
连接:双击redis-cli.exe
将redis添加到windows自启动服务中
#注册安装服务 redis-server --service-install redis.windows.conf --loglevel verbose #卸载服务 #redis-server --service-uninstall
2.2 Linux安装
下载
tar.gz
/usr/local
解压Redis的安装包
进入到解压文件夹下,进行基本的环境安装
yum install gcc-c++
make
升级到gcc9
sudo yum install centos-release-scl
sudo yum install devtoolset-7-gcc*
scl enable devtoolset-7 bash
进入
/usr/local/redis-6.0.10/src
目录下,可以启动redis
修改
redis.conf
配置文件
daemonize yes # 后台启动
启动
redis
$ src/redis-server
$ src/redis-cli
查看redis的进程是否开启
ps -ef | grep redis
关闭redis服务
shutdown
exit
2.3 测试性能
redis-benchmark
是一个压力测试工具
redis-benchmark -h localhost -p 6379 -n 100 -c 10000
3 Redis 基础知识
参考链接:http://doc.redisfans.com/
select index
dbsize
keys *
flushdb
flushall
Redis是单线程:Redis是很快的,官方表示,Redis是基于内存您操作的,CPU不是Redis性能瓶颈,Redis的瓶颈是根据机器的内存和网络带宽,既然可以使用单线程来实现,就是用单线程了,所有就使用了单线程了
Redis是C语言写的,官方提供的数据为100000+的QPS,完全不比同样使用key-value的Memecache差
Redis为什么这么快?
1 误区1: 高性能的服务器一定是多线程的?
2 误区2: 多线程(CPU上下文切换!)一定比单线程效率高?
先去CPU > 内存 > 硬盘的速度要有所了解
核心:redis是将所有的数据全部放在内存中的,所以说使用单线程去操作效率就是最高的,多线程(CPU上下文会切换:耗时的操作!),对于内存逆系统来说,如果没有上下文切换效率就是最高的!多次读写都是在一个CPU上的,在内存情况一定的,这个就是最佳方案。