NoSQL
(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库。 NoSQL
不依赖业务逻辑方式存储,而以简单的key-value
模式存储。因此大大的增加了数据库的扩展能力。它相比于传统的关系型数据库有以下几个区别:不遵循SQL标准、不支持ACID
原则、它的性能远超于SQL。
适用的场景
不适合的场景
最早出现的NoSql
数据库叫做Memcache
,它的数据都保存在内存中,需要频繁访问数据库的网站访问速度提升效果十分显著,一般不持久化,它只支持简单的key-value
模式,支持类型相对单一,它的作用一般是作为缓存数据库辅助持久化的数据库。
Redis
是一个key-value
存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string
(字符串)、list
(链表)、set
(集合)、zset
(sorted set --有序集合)和hash
(哈希类型)。它的数据类型都支持push/pop、add/remove
及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave
(主从)同步。
适用场景
场景一:配合关系型数据库做高速缓存
场景二:多样的数据结构存储持久化数据
Redis是单线程+多路IO复用技术
多路复用是指使用一个线程来检查多个文件描述符(Socket)的就绪状态,比如调用select和poll函数,传入多个文件描述符,如果有一个文件描述符就绪,则返回,否则阻塞直到超时。得到就绪状态后进行真正的操作可以在同一个线程里执行,也可以启动线程执行(比如使用线程池)。
一个场景说明多路IO复用技术:
相信大家都有去火车站买票的经历,遇到节假日的时候一票难求,这时在火车站就会有一种人,可以替人买票,我们亲切的将其称之为黄牛。有了黄牛的出现,我们可以把买票的需求告诉黄牛,让黄牛帮我们购买。有一天,有三个人找到黄牛让其帮忙购票,这时黄牛去火车站买票的过程为单线程操作,如果黄牛买到了三个人中某个人的票,通知其去黄牛哪里取票即可。假设第一个人想要去上海的票,通知黄牛去买票,黄牛在买票的时候,第一个人不用一直等待,可以做自己的事情,例如:吃饭、睡觉等,等到黄牛买到票后,通知第一个人取票就可。其他两个人也类似,也就是说这三个人都是在买票,但是在没有买到票的时候一直在干活,CPU一直处于工作状态,这个过程就是多路IO复用。
与Redis不同的是Memcache底层采用的是多线程+锁进行实现的。
第一步:下载Redis(我下载的是6.2.7版本)
第二步:测试 gcc版本 (安装redis依赖gcc)
gcc --version
如果没有gcc的话通过如下命令进行安装C语言编译环境
yum install centos-release-scl scl-utils-build
yum install -y devtoolset-8-toolchain
scl enable devtoolset-8 bash
第三步:解压下载的Redis tar.gz文件
tar -zxvf xxx
第四步:进入解压后的文件 执行make
命令进行编译
第五步:继续执行: make install
安装成功后会默认安装到/usr/local/bin
路径
redis-benchmark
:性能测试工具,可以在自己本子运行,看看自己本子性能如何redis-check-aof
:修复有问题的AOF文件,rdb和aof后面讲redis-check-dump
:修复有问题的dump.rdb文件redis-sentinel
:Redis集群使用redis-server
:Redis服务器启动命令redis-cli
:客户端,操作入口前台启动,命令行窗口不能关闭,否则服务器停止
redis-server
16
,默认数据库为0,可以使用SELECT
命令在连接上指定数据库idmax number of clients reached
”以作回应。