文章目录
- 一、NoSQL数据库
- 二、Redis 概述
- 三、在Linux环境下安装Redis
- 安装步骤
- 前台启动(不建议)
- 后台启动(推荐)
- 四、Redis配置文件解析
一、NoSQL数据库
NoSQL
(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库。 NoSQL
不依赖业务逻辑方式存储,而以简单的key-value
模式存储。因此大大的增加了数据库的扩展能力。它相比于传统的关系型数据库有以下几个区别:不遵循SQL标准、不支持ACID
原则、它的性能远超于SQL。
适用的场景
- 对数据高并发的读写
- 海量数据的读写
- 对数据有较高的扩展性
不适合的场景
- 需要支持事务相关的操作
- 基于sql的结构化查询存储,处理复杂的关系,需要即时查询
最早出现的NoSql
数据库叫做Memcache
,它的数据都保存在内存中,需要频繁访问数据库的网站访问速度提升效果十分显著,一般不持久化,它只支持简单的key-value
模式,支持类型相对单一,它的作用一般是作为缓存数据库辅助持久化的数据库。
二、Redis 概述
Redis
是一个key-value
存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string
(字符串)、list
(链表)、set
(集合)、zset
(sorted set --有序集合)和hash
(哈希类型)。它的数据类型都支持push/pop、add/remove
及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave
(主从)同步。
适用场景
场景一:配合关系型数据库做高速缓存
- 将高频次,热门访问的数据放到缓存中,降低数据库IO,提高查询性能
- 在分布式架构,最常见的问题就是session存在哪里,使用redis做缓存,将session数据放到redis中实现session共享。
场景二:多样的数据结构存储持久化数据
- 最常见的网站Top N 数据、最新的N 个数据、手机验证码等等,通过Redis的数据类型结构进行持久化的存储。
Redis是单线程 多路IO复用技术
多路复用是指使用一个线程来检查多个文件描述符(Socket)的就绪状态,比如调用select和poll函数,传入多个文件描述符,如果有一个文件描述符就绪,则返回,否则阻塞直到超时。得到就绪状态后进行真正的操作可以在同一个线程里执行,也可以启动线程执行(比如使用线程池)。
一个场景说明多路IO复用技术: 相信大家都有去火车站买票的经历,遇到节假日的时候一票难求,这时在火车站就会有一种人,可以替人买票,我们亲切的将其称之为黄牛。有了黄牛的出现,我们可以把买票的需求告诉黄牛,让黄牛帮我们购买。有一天,有三个人找到黄牛让其帮忙购票,这时黄牛去火车站买票的过程为单线程操作,如果黄牛买到了三个人中某个人的票,通知其去黄牛哪里取票即可。假设第一个人想要去上海的票,通知黄牛去买票,黄牛在买票的时候,第一个人不用一直等待,可以做自己的事情,例如:吃饭、睡觉等,等到黄牛买到票后,通知第一个人取票就可。其他两个人也类似,也就是说这三个人都是在买票,但是在没有买到票的时候一直在干活,CPU一直处于工作状态,这个过程就是多路IO复用。
与Redis不同的是Memcache底层采用的是多线程 锁进行实现的。
三、在Linux环境下安装Redis
安装步骤
第一步:下载Redis(我下载的是6.2.7版本)
点击进入Redis官方下载网页
第二步:测试 gcc版本 (安装redis依赖gcc)
代码语言:javascript复制gcc --version
如果没有gcc的话通过如下命令进行安装C语言编译环境
代码语言:javascript复制yum install centos-release-scl scl-utils-build
yum install -y devtoolset-8-toolchain
scl enable devtoolset-8 bash
第三步:解压下载的Redis tar.gz文件
代码语言:javascript复制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
:客户端,操作入口
前台启动(不建议)
前台启动,命令行窗口不能关闭,否则服务器停止
代码语言:javascript复制redis-server
后台启动(推荐)
- 备份redis.conf,拷贝一份redis.conf到其他目录
- 台启动设置daemonize no改成yes
- Redis启动
- 用客户端访问:redis-cli
- .Redis关闭
四、Redis配置文件解析
- 配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit。
- 类似jsp中的include,多实例的情况可以把公用的配置文件提取出来
- 默认情况bind=127.0.0.1只能接受本机的访问请求不写的情况下,无限制接受任何ip地址的访问,生产环境肯定要写你应用服务器的地址;服务器是需要远程访问的,所以需要将其注释掉
- 将本机访问保护模式设置no
- 默认端口号为:6379
- 一个空闲的客户端维持多少秒会关闭,0表示关闭该功能,即永不关闭。
- 是否为后台进程,设置为yes,守护进程,后台启动
- 存放pid文件的位置,每个实例会产生一个不同的pid文件
- 设定库的数量 默认
16
,默认数据库为0,可以使用SELECT<dbid>
命令在连接上指定数据库id
- 设置redis可以使用的内存量。一旦到达内存使用上限,redis将会试图移除内部数据.
- 建议必须设置,否则,将内存占满,造成服务器宕机
- 设置redis同时可以与多少个客户端进行连接。默认情况下为10000个客户端。
- 如果达到了此限制,redis则会拒绝新的连接请求,并且向这些连接请求方发出“
max number of clients reached
”以作回应。