Redis基础架构搭建实验
前言
本文重点在于后面的基础架构搭建过程,前面会简单的介绍非关系型数据库与关系型数据库的不同点和Redis的运用场景,如有遗漏与错误的地方,欢迎大家指正批评。
基本理论说明
NoSQL是什么?
NoSQL,指的是非关系型的数据库。NoSQL 有时也称作 Not Only SQL(意即”不仅仅是SQL”) 的缩写,其显著特点是不使用SQL作为查询语言,数据存储不需要特定的表格模式。
NoSQL(非关系型)数据库和SQL(关系型)数据库的各自主要代表
SQL
MariaDB、MySQL、SQLite、SQLServer、Oracle、PostgreSQL。
NoSQL
Redis、MongoDB、Memcache、HBASE。
NoSQL与SQL的应用场景
NoSQL适合存储非结构化数据
如发微博、文章、评论:
- 这些数据一般用于模糊处理,如全文搜索、机器学习
- 这些数据是海量的,并且增加的速度是难以预期的,
- 根据数据的特色,NoSQL数据库一般具备无限(至少接近)伸缩性
- 按key获取数据效率很高,可是对join或其余结构化查询的支持就比较差
关系型数据库适合存储结构化数据
如用户的账号、地址等:架构
-
这些数据一般须要作结构化查询,好比join,这时候,关系型数据库就要胜出一筹
-
这些数据的规模、增加的速度一般是能够预期的
-
保证数据的事务性、一致性要求。
目前许多大型互联网项目都会选用MySQL(或任何关系型数据库) + NoSQL的组合方案。
NoSQL(非关系型)数据库和SQL(关系型)数据库的区别
存储方式
- 关系型数据库是表格式的,因此存储在表的行和列中。他们之间很容易关联协作存储,提取数据很方便。
- NoSQL数据库则与其相反,它是大块的组合在一起。通常存储在数据集中,就像文档、键值对或者图结构。
存储结构
- 关系型数据库对应的是结构化数据,数据表都预先定义了结构(列的定义),结构描述了数据的形式和内容。预定义结构带来了可靠性和稳定性,但是修改这些数据比较困难。
- NoSQL数据库基于动态结构,使用与非结构化数据。由于NoSQL数据库是动态结构,可以很容易适应数据类型和结构的变化。
存储规范
- 关系型数据库的数据存储为了更高的规范性,把数据分割为最小的关系表以避免重复,获得精简的空间利用。
- NoSQL数据存储在平面数据集中,数据经常可能会重复。单个数据库很少被分隔开,而是存储成了一个整体,这样整块数据更加便于读写 。
存储扩展
- 关系型数据库数据存储在关系表中,操作的性能瓶颈可能涉及到多个表,需要通过提升计算机性能来克服,因此更多是采用纵向扩展 。
- NoSQL数据库是横向扩展的,它的存储天然就是分布式的,可以通过给资源池添加更多的普通数据库服务器来分担负载。
查询方式
- 关系型数据库通过结构化查询语言来操作数据库(即通常说的SQL)。SQL支持数据库CURD操作的功能非常强大,是业界的标准用法。
- NoSQL查询以块为单元操作数据,使用的是非结构化查询语言(UnQl),它是没有标准的。
- 关系型数据库表中主键的概念对应NoSQL中存储文档的ID。
- 关系型数据库使用预定义优化方式(比如索引)来加快查询操作,而NoSQL更简单更精确的数据访问模式。
事务
- 关系型数据库遵循ACID规则(原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability))。
- NoSQL数据库遵循BASE原则(基本可用(Basically Availble)、软/柔性事务(Soft-state )、最终一致性(Eventual Consistency))。
- 由于关系型数据库的数据强一致性,所以对事务的支持很好。关系型数据库支持对事务原子性细粒度控制,并且易于回滚事务。
- NoSQL数据库是在CAP(一致性、可用性、分区容忍度)中任选两项,因为基于节点的分布式系统中,不可能同时全部满足,所以对事务的支持不是很好。
实验步骤
实验目标:掌握Redis基本架构搭建
实验准备:C6标准虚拟机三台(防火墙与selinux已关闭)
实验规划:按照实验实际需求进行规划,此处不做规划。
ps:标准虚拟机安装见网络阶段Centos6安装指南
一、源码安装Redis
安装基本依赖
yum install -y gcc gcc-gcc+ tcl
准备好Redis安装包,解压安装。
cd redis-3.2.12
tar -zxvf redis-3.2.12.tar.gz
make
make PREFIX=/usr/local/redis install
或测试对应环境,新环境测试使用。
make test
复制配置文件至安装目录
cp redis.conf /usr/local/redis/
cd /usr/local/redis/
以前台方式运行Redis
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
修改redis文件,使其在后端运行。
vim redis.conf
修改128行,启用守护进程模式。
daemonize yes
保存退出,再次启动。
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
netstat -anpt | grep redis
redis已经转入后台运行,redis服务安装完毕。
redis密码设置
设置密码
vim /usr/local/redis/redis.conf
修改480行,取消注释,设置自定义密码。
requirepass 123456
保存退出,重启redis。
pkill redis
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
登陆redis,检查密码是否设置成功。
/usr/local/redis/bin/redis-cli
auth 123456
set name meiyajun
get name
登陆成功,密码生效。
redis数据备份设置
设置持久化文件的储存位置
vim /usr/local/redis/redis.conf
修改247行,设置持久化文件存储路径。
dir /usr/local/redis
保存退出,重启服务。
pkill redis
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
切换目录,查看是否能正常获取数据。
cd /
/usr/local/redis/bin/redis-cli -a 123456
get name
成功读取,持久化文件指定成功。
二、redis主从搭建
实验规划
192.168.10.10(主服务器)
192.168.10.11(从服务器)
1.主服务器基础配置
vim /usr/local/redis/redis.conf
修改61行,指定redis 实例绑定的接口地址。
bind 192.168.10.10
修改80行,关闭严格模式。
protected-mode no
修改128行, 设置redis以后台方式守护进程运行。
daemonize yes
修改247行,设置持久化文件存储路径。
dir /usr/local/redis
修改480行,配置服务器密码。
requirepass 123
保存退出,启动服务。
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
netstat -anpt | grep redis
登陆redis,创建数据文件,模拟已经工作了一段时间的状态。
/usr/local/redis/bin/redis-cli -h 192.168.10.10 -a 123
set name meiyajun
exit
为了节省时间,从主服务器直接拷贝redis至从服务器。
scp -r /usr/local/redis root@192.168.10.11:/usr/local
主服务器修改了配置文件,再从主服务器内拷贝一份新的配置文件到从服务器中。
scp /root/redis-3.2.12/redis.conf root@192.168.10.11:/root/
2.从服务器配置
将主服务器的redis默认配置文件覆盖至redis安装文件。
cp -a redis.conf /usr/local/redis/
修改主配置文件
vim /usr/local/redis/redis.conf
修改61行,指定redis 实例绑定的接口地址。
bind 192.168.10.11
修改80行,关闭严格模式。
protected-mode no
修改128行, 设置redis以后台方式守护进程运行。
daemonize yes
修改247行,设置持久化文件存储路径。
dir /usr/local/redis
修改265行,设置主服务器信息。
slaveof 192.168.10.11 6379
修改272行,设置主服务器密码信息。
masterauth 123
保存退出,重启服务。
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
登陆查看数据是否同步
/usr/local/redis/bin/redis-cli -h 192.168.10.11
get name
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-x9r6ielu-1605098036879)(F:\缓存\maskdown图片缓存区\image-20201108172902352.png)]
同步成功,主从搭建完毕。
三、Redis集群搭建
本实验由于篇幅较长,因此单独整理成一篇文章来讲解说明。
见Redis Cluster集群搭建实验
本文于2020年11月9日由Vonmerlot整理完成。
本文地址:https://blog.csdn.net/qq_46680028/article/details/109630665