一、Nosql
1.1、概念
首先数据库分为两种,即关系型数据库和非关系型数据库(也就是Nosql)。
NoSQL数据库,即非关系型数据库,提供了一种不同于传统关系型数据库的数据存储与管理方式。其特点包括灵活的数据模型、高可扩展性、高性能以及适用于大数据处理等。这些特性使NoSQL数据库在现代应用程序中越来越受欢迎,特别是在需要处理大规模、半结构化或非结构化数据的场景中。
1.2、分类
主要分为临时性键 值存储(memcached、Redis)、永久性键值存储(ROMA、Redis)、面向文档的数据库 (MongoDB、CouchDB)、面向列的数据库(Cassandra、HBase)。
二、redis
2.1、概念
Redis(Remote Dictionary Server)是一个开源的内存数据库,使用ANSI C编写,遵守BSD协议。它主要用作键值存储系统、缓存、消息队列和会话存储等。
2.2、特性
- 速度快: 10W QPS,基于内存,C语言实现
- 单线程
- 持久化
- 支持多种数据结构
- 支持多种编程语言
- 功能丰富: 支持Lua脚本,发布订阅,事务,pipeline等功能
- 简单: 代码短小精悍(单机核心代码只有23000行左右),单线程开发容易,不依赖外部库,使用简单
- 主从复制
- 支持高可用和分布式
2.2.1、单线程优势
- 纯内存
- 非阻塞
- 避免线程切换和竞态消耗
2.3、搭建
官方下载地址:Index of /releases/
2.3.1、编译搭建
首先部署三台主机
在node1中解压并安装编译包
data:image/s3,"s3://crabby-images/d242f/d242f9a8e0d7c85cce0363bd93ce63904e067f42" alt=""
dnf install make gcc initscripts-10.11.6 1.el9.x86_64 -y
执行编译
接着make && make install
启动redis
data:image/s3,"s3://crabby-images/a1577/a1577dc39648670afdc250e7a2892cc620a54f22" alt=""
然后会报错,接着前往 vim install_server.sh
对应位置注释掉
data:image/s3,"s3://crabby-images/2c67d/2c67d43f8ca1d8b19f1ac7fa3b359dc27503914e" alt=""
可以/system慢慢找,接着再次执行,一路enter
接着启动
data:image/s3,"s3://crabby-images/c4995/c499544f3bc2b9f4d67d810eee09478d4057a938" alt=""
2.3.2、配置redis
vim /etc/redis/6379.conf
防止找不到路径
data:image/s3,"s3://crabby-images/0326c/0326c928f822df9b62fab1539e905a5aa1548609" alt=""
/etc/init.d/redis_6379 restart 重启服务
接着端口查看
data:image/s3,"s3://crabby-images/ed994/ed99419346a9e06ba98e54de84cc407417c5d02f" alt=""
2.4、主从复制
2.4.1、环境
ip和nat网卡
在三台主机中vim /etc/redis/6379.conf
data:image/s3,"s3://crabby-images/743e8/743e80b07fd6e1d4cae0a08c78350375d4e81b00" alt=""
在node2,3中
data:image/s3,"s3://crabby-images/f0d91/f0d915c12cfa4b2d2819855bcdaa22d3b8e98de4" alt=""
2.4.2、测试
在主节点中node1中
data:image/s3,"s3://crabby-images/cbf26/cbf26afd4bbab5792433d7b672c636abb273e73f" alt=""
在slave中node2,3
data:image/s3,"s3://crabby-images/f6146/f6146dcea3777c4d8f9cba8443d2fbe742c31cf9" alt=""
2.5、哨兵(redis高可用)
2.5.1、概念
哨兵通过监控主从节点的运行状态,并在主节点故障时自动进行故障转移,确保服务的连续性和稳定性的一种机制。这种机制是一种分布式系统,用于对主从结构中的每台服务器进行监控。当主节点出现故障时,哨兵会自动选择一个从节点提升为主节点,并通知其他从节点和客户端更新配置。在上述的主从复制的步骤上大大优化,不需要人工干预。
2.5.2、实验过程
2.5.2.1、master节点
首先在master节点也就是node1上
data:image/s3,"s3://crabby-images/744d8/744d886b4fd3dbeae6689009d8091939ddf8e977" alt=""
更改以下设置(相隔太远就不拍了)
pidfile /var/run/redis-sentinel.pid
sentinel monitor mymaster 172.25.254.10 6379 2
sentinel down-after-milliseconds mymaster 10000
将文件复制到另外两台主机上
data:image/s3,"s3://crabby-images/7b726/7b7262efc1c94ace59b1e5e75f988a6193c8ee9d" alt=""
redis-sentinel /etc/redis/sentinel.conf 启动
data:image/s3,"s3://crabby-images/293c0/293c094897a9512281618da2bb6c48e75c08dee4" alt=""
2.5.2.2、测试
再开一台master节点的主机
data:image/s3,"s3://crabby-images/1d3da/1d3dad442335fb69b022aebeb391a8988913deb3" alt=""
data:image/s3,"s3://crabby-images/45ff9/45ff9eca7ed3295b5957626bbc185e480c65b548" alt=""
2.6、Redis cluster
2.6.1、概念
在哨兵sentinel机制中,可以解决redis高可用问题,即当master故障后可以自动将slave提升为master, 从而可以保证redis服务的正常使用,但是无法解决redis单机写入的瓶颈问题,即单机redis写入性能受 限于单机的内存大小、并发数量、网卡速率等因素。redis 3.0版本之后推出了无中心架构的redis cluster机制,在无中心的redis集群当中,其每个节点保存 当前节点数据和整个集群状态,每个节点都和其他所有节点连接。
2.6.2、实验过程
2.6.2.1、安装
为了方便就不源码编译了,直接yum
在原本三台主机的基础上再次部署三台主机(这里用的如果是mobashell可开启多执行模式,xshell还没搞清)
IP分别设置为172.25.254.110/120/130
为了配置统一,先将前三台node1,2,3的redis代码配置删掉
data:image/s3,"s3://crabby-images/f8399/f839957363e998e70f7fee032e310e64685b11de" alt=""
之后全部进行
Yum install redis -y
yum安装编译后修改配置文件
2.6.2.2、更改参数
在node1中
vim /etc/redis/redis.conf
检测发现6379已经打开了
data:image/s3,"s3://crabby-images/0ad66/0ad66d2cad3676b20800b36a72cd944100832675" alt=""
data:image/s3,"s3://crabby-images/a9e3c/a9e3c4913ac565345a64ba6923a71f6fddf1d5bd" alt=""
将配置文件发往其他主机
data:image/s3,"s3://crabby-images/7c7d3/7c7d3d0353407def69668636c6990d61c9bc1cc4" alt=""
data:image/s3,"s3://crabby-images/036f1/036f161f8bbf621ffcf8e56936c018a415079095" alt=""
成功后,在其他主机执行systemctl enable --now redis
data:image/s3,"s3://crabby-images/88899/888994cec6fa319038addd3d384c4b63bb193e6b" alt=""
2.6.3、创建redis cluster
接着在node1中创建集群
data:image/s3,"s3://crabby-images/44011/440115830bb3543734bf1350ff243198234ce575" alt=""
接着询问你是否进行配置选择yes
data:image/s3,"s3://crabby-images/108f7/108f7ff57b08236a2dc8ddd2625371c1c9b5bd45" alt=""
进行检测
data:image/s3,"s3://crabby-images/bd4b4/bd4b4f80a8d25a4002b8ae397e6148ba70058de0" alt=""
这里提示5798超过了node1的范围,上图显示是0-5461
data:image/s3,"s3://crabby-images/5fdc8/5fdc8fd94f098009862b9259f2342f0f240493b9" alt=""
所以得去node2中写
Node1,2,3是一个哈希层,数据分别存储到它们三台master主机中,而slave的作用是master或者说哈希层出现问题后,才会把数据存储到slave节点中。
2.6.4、集群扩容
再开两台主机
IP分别设置为172.25.254.50/150
首先下载redis包
Yum install redis -y
同时再把前面的几台主机的配置文件复制过去
data:image/s3,"s3://crabby-images/e6d83/e6d83d2db08dc1eb90e1fbc12b95689d4e7a1397" alt=""
然后再在新建两台主机打开redis服务
Systemctl start redis
通过以下命令进行添加master
redis-cli -a 123456 --cluster add-node 172.25.254.50:6379 172.25.254.20:6379
data:image/s3,"s3://crabby-images/2a9fd/2a9fdb8fb508c9768dcb3cb9ec487fd8b90cddc4" alt=""
这里可以看到添加成功
data:image/s3,"s3://crabby-images/ac259/ac259c2c081ed299a0184ad580d97011517a74c2" alt=""
接着重新分享槽位
data:image/s3,"s3://crabby-images/9b1dd/9b1dd830536b099274cd0fb942e8a583cd259b76" alt=""
这里16384分享给四个槽位所以/4
data:image/s3,"s3://crabby-images/42064/42064230ffdc8d73c3604909f61c65ddfdd0ee1f" alt=""
因为50没有,所以是50的id,id在check检测那一步可以看,然后选择所有人给他分配
每人都匀一点给他
data:image/s3,"s3://crabby-images/c2b32/c2b32b20dd52204ed63c02d2e92fe926fcd312a4" alt=""
接着会问你是否分配,yes就可以了
redis-cli -a 123456 --cluster check 172.25.254.10:6379
这里检测可以看到已经有槽位了
data:image/s3,"s3://crabby-images/7db25/7db257c5b3b6df858925d3b2a8511caaaefa0a19" alt=""
接着添加slava150
redis-cli -a 123456 --cluster add-node 172.25.254.150:6379 172.25.254.20:6379 --cluster-slave --cluster-master-id ef434540246ffaef763e4275756c062b7a387993
接着检测redis-cli -a 123456 --cluster check 172.25.254.20:6379
可以看到已经添加进去了,同时150变成了50的slave
data:image/s3,"s3://crabby-images/df0ab/df0abda4a5ffe742d5d40ba8deb7862c38b91fdd" alt=""
2.6.5、如何删除节点
2.6.5.1、首先删除slave
redis-cli -a 123456 --cluster del-node 172.25.254.150:6379 54a1810c38c8ddf0bf677d37b682ac645a9c922b
后面跟得是id
data:image/s3,"s3://crabby-images/12354/12354a11d82594def3f8bb45f668bd480fea17dc" alt=""
检测:可以看到已经没有150了
data:image/s3,"s3://crabby-images/cf7bc/cf7bcca17ad431fec9ca5b555698c48a4dfefaf5" alt=""
2.6.5.2、删除master
因为分配过槽位,有数据,不能直接删除,得先清除数据。
重新分配槽位
redis-cli -a 123456 --cluster reshard 172.25.254.20:6379
将50的分配给130
data:image/s3,"s3://crabby-images/03fe3/03fe3e9a5a8f5c6d156f127cd00e4413a0f2712b" alt=""
这里可以看到50上没有数据,所以可以进行删除
data:image/s3,"s3://crabby-images/80f6e/80f6e468424402ed54e83bba6b9d1c5e038cebbe" alt=""
data:image/s3,"s3://crabby-images/2acfe/2acfef781dc98d34cd64ff7bd6b513bf36aa8ff6" alt=""