Redis基础架构搭建实验

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

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐