1.非关系型数据库简介
许多Web应用都将数据保存到关系型数据库( RDBMS)中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大、访问的集中,就会出现RDBMS的负担加重、数据库响应恶化、 网站显示延迟等重大影响。Memcached/redis是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,减少对关系型数据库访问次数,以提高动态Web等应用的速度、 提高可靠性。
nosql产品:redis,mongodb,memcached.
非关系型数据库:以键值对的方式存储数据,缓存数据库
nosql的优缺点
优点:
- 高可扩展性
- 分布式计算
- 低成本
- 架构的灵活性
- 没有复杂的关系缺点:
- 没有标准化
- 有限的查询功能(到目前为止)
缓存数据库的作用:加快访问速度,缓解关系型数据库的读压力
2.关系型数据库与非关系型数据库的区别
1.首先了解一下 什么是关系型数据库?
关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织。优点:
1、易于维护:都是使用表结构,格式一致;
2、使用方便:SQL语言通用,可用于复杂查询;
3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。
缺点:
1、读写性能比较差,尤其是海量数据的高效率读写;
2、固定的表结构,灵活度稍欠;
3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈;二 非关系型数据库
什么非关系型数据库呢?非关系型数据是一种数据结构化存储方法的集合,可以是文档或者键值对等
优点:
1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。
2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;
3、高扩展性;
4、成本低:nosql数据库部署简单,基本都是开源软件。缺点:
1、不提供sql支持,学习和使用成本较高;
2、无事务处理;
3、数据结构相对复杂,复杂查询方面稍欠。
3.redis服务介绍
redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库
redis的特点
1.丰富的数据结构 -----String,list,set,hash等数据结构的存储
2.支持持久化
3.支持事务 ---------------事务是指“一个完整的动作,要么全部执行,要么什么也没有做”。
4.支持主从
4.安装redis
1.创建工作目录,然后下载redis
[root@web2 ~]# mkdir -p /data/applicaton
[root@web2 ~]# wget https://download.redis.io/releases/redis-6.2.7.tar.gz
2.解压到工作目录,然后改名
[root@web2 ~]# tar zxf redis-6.2.7.tar.gz -C /data/application/
[root@web2 ~]# cd /data/application/
[root@web2 application]# mv redis-6.2.7/ redis
[root@web2 application]# ls
redis
3.进入安装目录,安装工具,然后编译安装
[root@web2 application]# cd redis/
[root@web2 redis]# yum -y install gcc make
[root@web2 redis]# make
4.我们对配置文件进行备份
因为redis的配置文件内容比较多,所以我们直接配置我们用到的功能
[root@web2 redis]# mv redis.conf redis.conf.back
[root@web2 redis]# vim redis.conf
#监听所有网段--可以修改
bind 0.0.0.0
#开启后台模式
daemonize yes
#端口号 可以修改
port 6379
#本地数据库存放持久化数据的目录--需要自己创建
dir /data/application/redis/data
[root@web2 redis]# mkdir data
5.redis启动登录,以及设置密码
1.命令启动
我们先进入到安装目录下
[root@web2 redis]# cd /data/application/redis/
用相对路径的方式启动,停止
启动
[root@web2 redis]# nohup ./src/redis-server ./redis.conf &
关闭
[root@web2 redis]# ./src/redis-cli shutdown
登录
[root@web2 redis]# ./src/redis-cli -h localhost -p 6379 -a lzmima
-h 登录用户 -p 端口号 -a 密码
如果没有密码可以直接默认登录
[root@web2 redis]# ./src/redis-cli
2.设置systemctl启动
[root@web2 redis]# cd /lib/systemd/system
[root@web2 system]# vim redis.service
[Unit]
Description=Redis
After=network.target
[Service]
ExecStart=/data/application/redis/src/redis-server /data/application/redis/redis.conf --daemonize no
ExecStop=/data/application/redis/src/redis-cli -h 127.0.0.1 -p 6379 shutdown
[Install]
WantedBy=multi-user.target
参数详解:
• [Unit] 表示这是基础信息
• Description 是描述
• After 是在那个服务后面启动,一般是网络服务启动后启动• [Service] 表示这里是服务信息
• ExecStart 是启动服务的命令
• ExecStop 是停止服务的指令• [Install] 表示这是是安装相关信息
• WantedBy 是以哪种方式启动:multi-user.target表明当系统以多用户方式(默认的运行级别)启动时,这个服务需要被自动运行。
[root@web2 system]# systemctl daemon-reload 重新加载文件
[root@web2 system]# systemctl start redis.service 启动redis
但是登录还是要用二进制命令 [root@web2 redis]# ./src/redis-cli 注意我是在工作目录内,用的相对路径,如果不在工作目录请用绝对路径 [root@web2 ~]# /data/application/redis/src/redis-cli
3.给redis设置密码
1.临时密码,redis服务关闭即失效
我们先登录redis
[root@b-2 ~]# cd /data/application/redis/
[root@b-2 redis]# ./src/redis-cli
127.0.0.1:6379> ping
PONG
然后我们在redis内部设置密码
127.0.0.1:6379> config set requirepass lzmima
OK
然后我们退出重新登录
不加密码登录失败
登录成功
2.永久设置密码,修改配置文件
在配置文件里修改
requirepass 12345