欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Redis基础架构搭建实验

程序员文章站 2022-04-01 19:00:40
Redis基础架构搭建实验前言本文重点在于后面的基础架构搭建过程,前面会简单的介绍非关系型数据库与关系型数据库的不同点和Redis的运用场景,如有遗漏与错误的地方,欢迎大家指正批评。基本理论说明NoSQL是什么?NoSQL,指的是非关系型的数据库。NoSQL 有时也称作 Not Only SQL(意即"不仅仅是SQL") 的缩写,其显著特点是不使用SQL作为查询语言,数据存储不需要特定的表格模式。NoSQL(非关系型)数据库和SQL(关系型)数据库的各自主要代表SQLMariaDB、MySQ...

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基础架构搭建实验

修改redis文件,使其在后端运行。

vim  redis.conf

修改128行,启用守护进程模式。

daemonize yes

Redis基础架构搭建实验

保存退出,再次启动。

/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
netstat -anpt | grep redis

Redis基础架构搭建实验

redis已经转入后台运行,redis服务安装完毕。

redis密码设置

设置密码

vim /usr/local/redis/redis.conf

修改480行,取消注释,设置自定义密码。

requirepass 123456

Redis基础架构搭建实验

保存退出,重启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基础架构搭建实验

登陆成功,密码生效。

redis数据备份设置

设置持久化文件的储存位置

vim /usr/local/redis/redis.conf

修改247行,设置持久化文件存储路径。

dir /usr/local/redis

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基础架构搭建实验

成功读取,持久化文件指定成功。

二、redis主从搭建

实验规划

192.168.10.10(主服务器)

192.168.10.11(从服务器)

1.主服务器基础配置

vim /usr/local/redis/redis.conf

修改61行,指定redis 实例绑定的接口地址。

bind 192.168.10.10

Redis基础架构搭建实验

修改80行,关闭严格模式。

protected-mode no

Redis基础架构搭建实验

修改128行, 设置redis以后台方式守护进程运行。

daemonize yes

Redis基础架构搭建实验

修改247行,设置持久化文件存储路径。

dir /usr/local/redis

Redis基础架构搭建实验

修改480行,配置服务器密码。

requirepass 123

Redis基础架构搭建实验

保存退出,启动服务。

/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
netstat -anpt | grep redis

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