****NoSQL****即Not-Only SQL是关系型数据库的良好补充
****关系型数据库****是基于关系模型提出来的数据库.那么什么是关系模型呢?以行和列的方式二维表的方式存储数据的模型就是关系型数据库.例如:mysql和oracle
随着互联网web网站的兴起,关系型数据库暴露的缺点越来越多,关系型数据库可以应付上万次的sql查询,但是对于上万次的sql写数据的请求,硬盘io就受不鸟了
****硬盘****:用来存储数据的计算机配件。是非易失性储存器,说得直白点,就是你关了机,里面的数据也不会丢。
****内存条****:由于硬盘速度比较慢,CPU如果运行程序的时候,所有数据都直接从硬盘中读写,会非常影响效率。所以CPU会将运行软件时要用的数据一次性从硬盘调用到运行速度很快的内存,然后再CPU再与内存进行数据交换。
内存是易失性存储器,只要你断了电,内存中的数据就没有了。
单一应用架构
Web1.0的时代,数据访问量很有限,用一夫当关的高性能的单点服务器可以解决大部分问题。
随着互联网的用户越来越多。
单一的架构已经不能满足日常的时候。我们的架构也从单一架构变成的分布式。
为了缓解关系型数据库的压力,我们出现Nosql数据库
经常读取的数据放入缓存数据库中。
数据库的存储方式会决定该数据库的对于某些操作的性能
再redis官网中只能去下载Linux的版本,对于window官网没有提供。
但是window自己开发过,可以去找一下。
官网
redis.io
再安装Redis前需要进行安装C语言的编译环境
redis就是c语言编写的
连接网路的情况下将这些命令一一执行即可
yum install centos-release-scl scl-utils-build
yum install -y devtoolset-8-toolchain
scl enable devtoolset-8 bash
测试 gcc版本
gcc --version
redis-6.2.1.tar.gz放/opt目录
开始解压
tar -zxvf redis的压缩文件
解压后进入压缩后目录
cd 压缩后目录
通过刚刚安装好的语言环境进行编译
make
如果失败,说明gcc没有安装好
清除编译内容
make distclean
执行编译内容
make install
可以将编译和执行编译结合
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,不值得推荐
进入/usr/local/bin
redis-server
退出前台启动
ctrl+c
我们一般进行后台启动。后台启动之后我们可以代开
redis-cli进redis的命令操作
后台启动是根据redis的配置文件启动。
我们再启动的时候通过指定redis配置文件启动
拷贝redis的redis.conf文件。避免配置错误
当然通过拷贝的文件也可以启动
开启后台启动
daemonize no 改成yes
可以进行操作redis命令
启动服务端
redis-server 指定配置文件
测试服务端时候启动
ps -ef |grep redis
启动客户端
redis-clid
再客户端中关闭服务端
shutdown
端口:默认6379
默认16个数据库,类似数组下标从0开始
初始默认使用0号库 使用命令 select 来切换数据库。如: select 8
统一密码管理,所有库同样密码。
dbsize查看当前数据库的key的数量
flushdb清空当前库
flushall通杀全部库
串行 vs 多线程+锁(memcached) vs 单线程+多路IO复用(Redis)
与Memcache三点不同: 支持多数据类型,支持持久化,单线程+多路IO复用
多路复用是指使用一个线程来检查多个文件描述符(Socket)的就绪状态,比如调用select和poll函数,传入多个文件描述符,如果有一个文件描述符就绪,则返回,否则阻塞直到超时。得到就绪状态后进行真正的操作可以在同一个线程里执行,也可以启动线程执行(比如使用线程池)