redis 集群搭建以及redislive监测部署

redis 集群搭建以及监测环境

实现3主3从的集群 虚拟机单机ip:192.168.40.128

集群基本搭建

简单下载

通过 wget http://download.redis.io/releases/redis-4.0.10.tar.gz

解压缩 tar zxvf redis-4.0.10.tar.gz

指定安装路径,切换root用户执行make && make PREFIX=/usr/local/redis install,可能出现权限不够的问题,sudo同样会报错,直接使用root进行操作。

安装编译工具

sudo apt-get update

sudo apt-get install gcc

sudo apt-get install make

sudo apt-get install tcl

创建redis集群文件夹

因为是/usr,所以始终都是在root权限下进行操作

cd /usr/local/redis

mkdir cluster

cd cluster

mkdir 7000 7001 7002 7003 7004 7005

修改配置文件

复制redis conf内的config文件复制到六个文件夹中,并且修改以下内容

# 端口号  port 7000  # 后台启动  daemonize yes  # 开启集群  cluster-enabled yes  #集群节点配置文件  cluster-config-file nodes-7000.conf  # 集群连接超时时间  cluster-node-timeout 5000  # 进程pid的文件位置  pidfile /home/ubuntu/redis-4.0.10/pid/redis-7000.pid#工作文件夹dir "/home/ubuntu/redis-4.0.10/working"# 开启aof  appendonly yes  # aof文件路径  appendfilename "appendonly-7005.aof"  # rdb文件路径  dbfilename dump-7000.rdb

登录后复制

redis 的配置文件中的bind指定的是redis服务器的网卡ip,也就是redis服务器的ip

启动脚本

cd /home/ubuntu/redis-4.0.10/

touch start.link.sh为了操作简单,创建脚本

修改启动脚本,为

#!/bin/bashexport BASE_FLOD="/usr/local/redis"{BASE_FLOD}/bin/redis-server /usr/local/redis/cluster/7000/redis.conf/usr/local/redis/bin/redis-server /usr/local/redis/cluster/7001/redis.conf/usr/local/redis/bin/redis-server /usr/local/redis/cluster/7002/redis.conf/usr/local/redis/bin/redis-server /usr/local/redis/cluster/7003/redis.conf/usr/local/redis/bin/redis-server /usr/local/redis/cluster/7004/redis.conf/usr/local/redis/bin/redis-server /usr/local/redis/cluster/7005/redis.conf#cd src#./redis-trib.rb create --replicas 1 192.168.40.128:7000 192.168.40.128:7001 192.168.40.128:7002 192.168.40.128:7003 192.168.40.128:7004 192.168.40.128:7005

登录后复制

其中注释的是为了简化初始启动的,ip需要跟每个节点配置的redis.conf 中bind 属性绑定的一致,启动后可以通过ps -ef | grep redis命令查询对应的线程是否启动

集群启动

关联程序使用的ruby写的,所以要搭建rudy的运行环境,需要安装rudbygem

sudo apt-get install ruby rubygems -y

gem install redis,运行到这里会感觉十分慢,需要耐心等待,在redis安装目录下,src文件夹redis-trib.rb

运行redis-trib.rb create –replicas 1 192.168.40.128:7000 192.168.40.128:7001 192.168.40.128:7002 192.168.40.128:7003 192.168.40.128:7004 192.168.40.128:7005,检查配置的信息是否有错误,没有直接yes就可以.  [OK] All 16384 slots covered.代表接群启动成功。

节点查看,重启

查看集群运行状态:使用命令./redis-trib.rb check 192.168.40.128:7000,进行集群的状态检查

性能测试

自带测试工具redis-benchmark

redis-benchmark -h 192.168.40.128 -p 6379 -c 100 -n 100000100个并发连接,100000个请求,检测 host 为 localhost 端口为6379的 redis 服务器性能。

redis-benchmark -h 192.168.40.128 -p 6379 -q -d 100测试存取大小为100字节的数据包的性能。

redis-benchmark -t set,lpush -n 100000 -q只测试某些操作的性能。

redis-benchmark -n 100000 -q script load “redis.call(‘set’,’foo’,’bar’)”只测试某些数值存取的性能。

集群密码设置

集群搭建初始不需要密码,启动完成后,先看每个节点的配置文件是否有读写权限,如果没有读写权限,需要chmod修改的读写权限,通过

./redis-cli -c -p portconfig set masterauth passwordconfig set requirepass passwordconfig rewrite

登录后复制

分别连接每个节点进行设置
若要重启发现连接不上,修改启动脚本 redis-.sh 99行,配置启动脚本密码启动
@r = Redis.new(:host => @info[:host], :port => @info[:port], :timeout => 60,:password => “yangfan@1995”)

代码测试

/* *集群连接测试 */@Testpublic void testJedisCluster() {    Set nodes = new LinkedHashSet();    //所有主机节点ip和端口    nodes.add(new HostAndPort("192.168.40.128", 7000));    nodes.add(new HostAndPort("192.168.40.128", 7001));    nodes.add(new HostAndPort("192.168.40.128", 7002));    nodes.add(new HostAndPort("192.168.40.128", 7003));    nodes.add(new HostAndPort("192.168.40.128", 7004));    nodes.add(new HostAndPort("192.168.40.128", 7005));    //没有密码    //JedisCluster cluster = new JedisCluster(nodes);    //添加密码调用    JedisCluster cluster = new JedisCluster(nodes, 5000, 5000, 10, "yangfan@1995", new GenericObjectPoolConfig());    //cluster.zadd("test_1", String.valueOf(""),"id_2");    System.out.println(cluster.zscore("test_1", "id_1"));    try {        cluster.close();    } catch (IOException e) {        e.printStackTrace();    }}

登录后复制

主从模式、哨兵、集群的关系

主从模式是指定复制和持久化关系,指定了主从备份的关系

哨兵:当主数据库遇到异常中断服务后,开发者可以通过手动的方式选择一个从数据库来升格为主数据库,以使得系统能够继续提供服务。主要是为了解决主从复制手动切换主从关系的检测工具,可以自动切换主从。

使用哨兵,redis每个实例也是全量存储,每个redis存储的内容都是完整的数据,浪费内存且有木桶效应。为了最大化利用内存,可以采用集群,就是分布式存储。即每台redis存储不同的内容,共有16384个slot。每个redis分得一些slot,hash_slot = crc16(key) mod 16384 找到对应slot,键是可用键,如果有{}则取{}内的作为可用键,否则整个键是可用键集群至少需要3主3从,且每个实例使用不同的配置文件,主从不用配置,集群会自己选。

监控部署

RedisLive搭建部署

运行环境部署

git clone https://github.com/kumarnitin/RedisLive.git
  下载redislive,解压缩unzip -o -d /home/ubuntu/ RedisLive-master.zip

进入src文件夹,复制example文件,编辑

"RedisServers":[    {    "server": "192.168.40.128",    "port" : 7000,    "password" : "yangfan@1995"    },    //...多个监听],"DataStoreType" : "redis","RedisStatsServer": //存储的redis监听接口{    "server" : "127.0.0.1",    "port" : 6379},"SqliteStatsStore" :{    "path":  "/home/ubuntu/redis-4.0.10/working/redislive.db" //进行存储的文件} }

登录后复制

ubuntu@ubuntu:~/redis-4.0.10$ mkdir pid  
ubuntu@ubuntu:~/redis-4.0.10$ mkdir log  
ubuntu@ubuntu:~/redis-4.0.10$ mkdir working
  //保存aof,rdb,node-config文件。

RedisLive分为两部分,其中一部分为监控脚本,另一部分为web服务,所以需要分别启动。`./redis-monitor.py
  –duration=120`./redis-live.py

Q&A

redis.clients.jedis.exceptions.JedisNoReachableClusterNodeException: No reachable node in cluster redis node的redis.conf 绑定ip设置为指定的redis节点ip,启动集群时只用指定ip启动,不使用192.168.40.128

connect refuse  关闭防火墙

No module named redis

查看python位置 which python

先备份 sudo cp /usr/bin/python /usr/bin/python_cp

删除 sudo rm /usr/bin/python

默认设置成python3.5,创建链接 sudo ln -s /usr/bin/python3.5 /usr/bin/python

相关推荐:

Redis集群搭建全记录

Redis集群部署及常用的操作命令

以上就是redis 集群搭建以及redislive监测部署的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2594742.html

(0)
上一篇 2025年3月6日 17:38:01
下一篇 2025年3月2日 19:15:26

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Java中IDE的历史及idea的使用介绍

    本篇文章给大家带来的内容是关于Java中IDE的历史及idea的使用介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 Java开发工具的历史变迁 JCreator Jcreator是荷兰的Xinox Software公司…

    2025年3月6日 编程技术
    200
  • 当编程语言掌握在企业手中,是生机还是危机?

    2019 年 4 月,Java 8 收费时代到来了!2019 年 1 月份,Oracle 宣布将停止 Java 8 更新的免费支持,未来 Java 的更新只适用于已付费的许可证持有者。近日,Oracle 发送邮件通知用户 Java 8 第一…

    2025年3月6日
    200
  • jdk工具包括什么?

    jdk工具包括:Java运行环境、javac、java、jdb、appletviewer、extcheck、idlj、jar、jarsigner、javadoc、javafxpackager、javah、javap、jdb、rmic、jst…

    2025年3月6日
    200
  • 用什么软件编辑Java

    java应用程序越做越大、越做越复杂。java ide(集成开发环境)在其中所起的作用也日益显著。有了java ide,使软件的生产率倍增。本文为大家介绍几款时下最为流行的java ide。 编辑Java的软件有: 一、Eclipse   …

    2025年3月6日
    200
  • java敲代码用什么软件

    作为一名java程序开发人员,可以的选择集成开发环境ide(integrated development environment)非常多,得益于java是一门开源语言。有开源免费的;有商用收费的。如何选择一款适合自己的集成开发环境,亦或说选…

    2025年3月6日
    200
  • java是用什么编译器

    JAVA编译器(javac.exe)的作用是将java源程序编译成中间代码字节码文件,是最基本的开发工具。 java程序开发人员,可以的选择集成开发环境IDE(Integrated Development Environment)非常多  …

    2025年3月6日
    200
  • Java 有没有必要转 Go 语言?

    Java 有没有必要转 Go 语言? 可以根据情况来看是否有必要转Go语言,如果对Go语言感兴趣,并且条件允许推荐转Go语言,Go语言是一种静态强类型、编译型语言,不仅语法比Java简洁,而且性能比Java更好,编译速度更快。 Go 在并发…

    2025年3月6日
    200
  • 简单聊聊java面向对象

    本篇文章给大家带来了关于java的相关知识,其中主要介绍了java面向对象的相关问题,包括了面向对象的基本特性、对象间的关系等等相关内容,希望对大家有帮助。 推荐学习:《java教程》 一、Java特效 1、简单性 人们希望构建一个无须深奥…

    2025年3月6日
    200
  • java中orm框架有哪些

    1.Hiberante 面向对象的ORM,学习成本比较高。 2.Mybatis 半自动orm框架,需要自己写sql, 方便sql与java代码分离。这里所谓的 “半自动” 是相对于 Hibernate 框架全表映射而言的,MyBatis 框…

    编程技术 2025年3月6日
    200
  • 利用Java、Selenium和OpenCV结合的方法,解决自动化测试中滑块验证问题。

    1、滑块验证思路 被测对象的滑块对象长这个样子。相对而言是比较简单的一种形式,需要将左侧的拼图通过下方的滑块进行拖动,嵌入到右侧空槽中,即完成验证。 要自动化完成这个验证过程,关键点就在于确定滑块滑动的距离。 根据上面的分析,验证的关键点在…

    2025年3月6日 编程技术
    200

发表回复

登录后才能评论