Redis集群搭建

redis单机版安装

  1. 环境准备

redis安装在Linux上,redis是c语言开发的,需要gcc-c++环境
查看是否安装gcc-c++
[root@itcast-01 ~]# rpm -qa | grep gcc-c++
gcc-c+±4.4.7-17.el6.i686
如果没有安装,可以使用yum命令进行网络安装
[root@itcast-01 ~]# yum install gcc-c++
1.上传安装包
在Linux的CRT客户端,按alt+p进行上传,可以直接把安装包拖动上去
进入root目录,查看上传包
解压安装包

tar -zxvf redis-3.0.2.tar.gz
2. 执行安装
进入解压的文件夹,进行编译
cd redis-3.0.2
make
成功效果:
在这里插入图片描述
执行安装,指定安装路径
[root@itcast-01 redis-3.0.2]# make install PREFIX=/usr/local/redis
成功效果:
在这里插入图片描述
查看安装目录

进入目录
cd /usr/local/redis/bin/
在这里插入图片描述
常用的是客户端和服务端
redis-cli 是客户端
redis-server 是服务端
启动redis

1.前端启动

启动命令
./redis-server
确认redis安装正常,效果:
在这里插入图片描述
修改为后端启动

从安装包中复制redis.conf文件到/usr/local/redis/bin中
cp /root/redis-3.0.2/redis.conf ./
修改redis.conf配置文件,修改为yes
vim redis.conf
在这里插入图片描述
启动命令
./redis-server redis.conf
查看启动效果:
ps -ef | grep redis
在这里插入图片描述
使用图形化界面测试访问成功
在这里插入图片描述

redis集群版搭建

	1. Redis集群版原理
		1. Redis-cluster架构图




1. 

所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽。

1. 

节点的fail是通过集群中超过半数的节点检测失效时才生效。

(3)客户端与redis节点直连,不需要中间proxy层.客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可。
(4)redis-cluster把所有的物理节点映射到[0-16383]slot上,cluster 负责维护node<->slot<->value
Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点

		1. 

redis-cluster投票:容错

(1)投票过程是集群中所有master参与,如果半数以上master节点与master节点通信超时(cluster-node-timeout),认为当前master节点挂掉.
(2):什么时候整个集群不可用(cluster_state:fail)?
a:如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完整时进入fail状态. ps : redis-3.0.0.rc1加入cluster-require-full-coverage参数,默认关闭,打开集群兼容部分失败.
b:如果集群超过半数以上master挂掉,无论是否有slave,集群进入fail状态.

	1. 

Redis集群搭建

为了保证可以进行投票,需要至少3个主节点。
每个主节点都需要至少一个从节点,所以需要至少3个从节点
一共需要6台redis服务器
可以使用6个redis实例
6个redis实例的端口号,7001~7006
不要求学员搭建集群,只需要打开Redis集群的节点,启动命令:
[root@itcast-01 ~]# cd /usr/local/redis/redis-cluster
[root@itcast-01 ~]# ./start-all.sh

		1. 

准备6个redis实例

1. 

把bin目录里面的rdb,和aof文件删除,准备干净的redis

[root@localhost bin]# rm -rf appendonly.aof
[root@localhost bin]# rm -f dump.rdb
效果:

1. 

把bin复制6份

[root@localhost bin]# cd …
[root@localhost redis]# cp -r bin redis-cluster/redis1
[root@localhost redis]# cp -r bin redis-cluster/redis2
[root@localhost redis]# cp -r bin redis-cluster/redis3
[root@localhost redis]# cp -r bin redis-cluster/redis4
[root@localhost redis]# cp -r bin redis-cluster/redis5
[root@localhost redis]# cp -r bin redis-cluster/redis6
1.
修改端口号

依次修改端口号为7001~7006

1. 

启动6个redis实例

编写脚本实现
1.
编写脚本

[root@localhost redis-cluster]# vim start-all.sh
cd redis1
./redis-server redis.conf
cd …
cd redis2
./redis-server redis.conf
cd …
cd redis3
./redis-server redis.conf
cd …
cd redis4
./redis-server redis.conf
cd …
cd redis5
./redis-server redis.conf
cd …
cd redis6
./redis-server redis.conf
cd …
1.
设置脚本启动权限

[root@localhost redis-cluster]# chmod u+x start-all.sh
1.
执行脚本

[root@localhost redis-cluster]# ./start-all.sh
[root@localhost redis-cluster]# ps aux | grep redis
效果

		1. 

准备redis集群的安装环境

redis集群的管理工具使用的是ruby脚本语言,安装集群需要ruby环境。
安装ruby环境(老师提供的虚拟机,环境已经装好)
[root@itcast-01 redis-cluster]# yum install ruby
安装Ruby的打包系统
[root@itcast-01 redis-cluster]# yum install rubygems
安装redis的ruby接口库

先上传,再执行命令安装
[root@itcast-01 ~]# gem install redis-3.0.0.gem

安装redis集群

需要修改每个实例的redis.conf配置文件,开启redis-cluster
[root@localhost redis-cluster]# vim redis1/redis.conf

需要修改6个节点
重启redis实例
[root@localhost redis-cluster]# ./start-all.sh
集群管理工具在redis解压文件夹的src的文件夹中
使用redis-cluster的集群管理工具启动集群

先进入集群管理工具所在的路径
[root@localhost redis-cluster]# cd /root/redis-3.0.0/src/
再启动命令(注意修改为自己的ip最好不用127.0.0.1和port)
[root@localhost src]# ./redis-trib.rb create --replicas 1 192.168.37.161:7001 192.168.37.161:7002 192.168.37.161:7003 192.168.37.161:7004 192.168.37.161:7005 192.168.37.161:7006
启动信息

Creating cluster
Connecting to node 192.168.37.131:7001: OK
Connecting to node 192.168.37.131:7002: OK
Connecting to node 192.168.37.131:7003: OK
Connecting to node 192.168.37.131:7004: OK
Connecting to node 192.168.37.131:7005: OK
Connecting to node 192.168.37.131:7006: OK

Performing hash slots allocation on 6 nodes…
Using 3 masters:
192.168.37.131:7001
192.168.37.131:7002
192.168.37.131:7003
Adding replica 192.168.37.131:7004 to 192.168.37.131:7001
Adding replica 192.168.37.131:7005 to 192.168.37.131:7002
Adding replica 192.168.37.131:7006 to 192.168.37.131:7003
M: 955567f988830cdf4328854f815719ea28082ca8 192.168.37.131:7001
slots:0-5460 (5461 slots) master
M: 4f3eeced04b930aa48193699301745a05a70697a 192.168.37.131:7002
slots:5461-10922 (5462 slots) master
M: 871a684dbbc0f43dcc16107710d7bd2f4e6de76a 192.168.37.131:7003
slots:10923-16383 (5461 slots) master
S: baca3ce2223dfcd9c636a7193b12998b1dbb2431 192.168.37.131:7004
replicates 955567f988830cdf4328854f815719ea28082ca8
S: 0b599863ddf2e03b0326c75b874a1af8ae430d2e 192.168.37.131:7005
replicates 4f3eeced04b930aa48193699301745a05a70697a
S: 92f712d954c62f2743e2e572f6582a6ef9a163e0 192.168.37.131:7006
replicates 871a684dbbc0f43dcc16107710d7bd2f4e6de76a
Can I set the above configuration? (type ‘yes’ to accept): yes

Nodes configuration updated
Assign a different config epoch to each node
Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join…

Performing Cluster Check (using node 192.168.37.131:7001)
M: 955567f988830cdf4328854f815719ea28082ca8 192.168.37.131:7001
slots:0-5460 (5461 slots) master
M: 4f3eeced04b930aa48193699301745a05a70697a 192.168.37.131:7002
slots:5461-10922 (5462 slots) master
M: 871a684dbbc0f43dcc16107710d7bd2f4e6de76a 192.168.37.131:7003
slots:10923-16383 (5461 slots) master
M: baca3ce2223dfcd9c636a7193b12998b1dbb2431 192.168.37.131:7004
slots: (0 slots) master
replicates 955567f988830cdf4328854f815719ea28082ca8
M: 0b599863ddf2e03b0326c75b874a1af8ae430d2e 192.168.37.131:7005
slots: (0 slots) master
replicates 4f3eeced04b930aa48193699301745a05a70697a
M: 92f712d954c62f2743e2e572f6582a6ef9a163e0 192.168.37.131:7006
slots: (0 slots) master
replicates 871a684dbbc0f43dcc16107710d7bd2f4e6de76a
[OK] All nodes agree about slots configuration.

Check for open slots…
Check slots coverage…
[OK] All 16384 slots covered.

redis集群连接

redis的单机版,默认是16个数据库,但是redis-Cluster集群版,只有一个数据库

使用redis命令行客户端连接

[root@localhost bin]# ./redis-cli -h 192.168.37.131 -p 7006 -c
192.168.37.131:7006> set hello money
-> Redirected to slot [866] located at 192.168.37.131:7001
OK
一定要加-c参数,节点之间就可以互相跳转

redis的java客户端连接(Jedis)

使用的是JedisCluster类进行连接

public class JedisClusterTest {
    public static void main(String[] args) {
       // 1. 创建JedisCluster对象
       // 设置节点信息,放到set中
       Set<HostAndPort> nodes = new HashSet<>();
       nodes.add(new HostAndPort("192.168.37.136", 7001));
       nodes.add(new HostAndPort("192.168.37.136", 7002));
       nodes.add(new HostAndPort("192.168.37.136", 7003));
       nodes.add(new HostAndPort("192.168.37.136", 7004));
       nodes.add(new HostAndPort("192.168.37.136", 7005));
       nodes.add(new HostAndPort("192.168.37.136", 7006));
       // 创建对象
       JedisCluster jedisCluster = new JedisCluster(nodes);
       // 2. 使用jedisCluster操作redis,方法和jedis是一样的
       String key = "jedisCluster";
       String setResult = jedisCluster.set(key, "Hello redis !");
       String getResult = jedisCluster.get(key);
       System.out.println(setResult + ":" + getResult);
       // 3. 关闭jedisCluster连接(在程序执行完之后,才能关闭,他的内部已经封装了连接池)
       jedisCluster.close();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值