redis -cli command not found_redis集群的创建,redis集群卡槽迁移报错ERR syntax error详细说明与验证

本文介绍了如何使用redis-cli 5.0.7创建和操作Redis集群,包括从三主三从扩容到五主五从的过程,并详细讨论了在不同版本中迁移卡槽时遇到的`ERR syntax error`问题,强调了4.0.7版本开始支持AUTH参数的重要性。
摘要由CSDN通过智能技术生成

前言

redis5.0.0之前操作redis集群用的是ruby写的脚本redis-trib.rb,这样带来的弊端就是需要安装rubygems环境,官方拉取的docker镜像里是没有redis-trib.rbruby环境的,需要自己安装,在国内网络环境下还是比较费时复杂的,也不容易成功,而且最后制作的docker镜像也比较大。再者安装的ruby、redis扩展版本不对,也会导致操作集群时,报各种各样的错误。

最重要的硬伤是redis-trib.rb不能操作带密码的redis集群,虽然github上有人在redis-trib.rb脚本基础上已经加了密码支持。但对于move_slots的迁移卡槽相关的操作,我试了还是没加。可以查看以下的提交记录:

Redis-Cluster: Add support to auth in redis-trib.rb #4288

redis5.0.0之后的redis-cli可以直接操作redis集群,可以支持带密码操作,可以说带来了很大的方便。但是在redis4.0.7版本之前迁移卡槽本来就是不支持密码auth参数的,以下命令中的[AUTH password]redis4.0.7版本才支持。

MIGRATE host port key|"" destination-db timeout [COPY] [REPLACE] [AUTH password] [KEYS key [key ...]]

具体可以查看官方文档:MIGRATE说明文档

Options
COPY -- Do not remove the key from the local instance.
REPLACE -- Replace existing key on the remote instance.
KEYS -- If the key argument is an empty string, the command will instead migrate all the keys that follow the KEYS option (see the above section for more info).
AUTH -- Authenticate with the given password to the remote instance.
COPY and REPLACE are available only in 3.0 and above. KEYS is available starting with Redis 3.0.6. AUTH is available starting with Redis 4.0.7.

我们最近容器化时,用到的版本为redis3.2.6,在redis集群有数据(有hash数据时必现),且带有密码时,从3主3从扩规模到5主5从时,用5.0.7的redis-cli操作redis:3.2.6集群,执行迁移卡槽命令时,报ERR syntax error错误。

ed986ee3f9e0cb857b8e5d527f81b11b.png

试着用github上加密码的redis-trib.rb操作3.2.6集群,进行卡槽迁移时报错[ERR] Calling MIGRATE: ERR Target instance replied with error: NOAUTH Authentication required

6cd84f11eb6b612e1a202351ec5b79b6.png

这个是因为github上的redis-trib.rb没在move_slots操作时,加密码参数。于是乎,我试着自己在迁移卡槽的地方传入密码参数,像下面这样:

source.r.client.call(["migrate",target.info[:host],target.info[:port],"",0,@timeout,:auth,target.info[:password],:keys,*keys])

加了之后执行卡槽迁移时,也报ERR syntax error错误。从这可以看出,redis3.2.6集群确实在migrate时不支持密码参数。那么下面在redis4.0.7集群上进行验证,是否可以正常迁移卡槽。

创建三主三从集群

创建configmaps

将以下内容保存到redis-test.conf文件:

#设置为守护进程
daemonize no
#Redis运行的进程pid文件
pidfile redis-6397.pid
#Redis服务端口号
port 6379
#Redis服务绑定ip
#bind 192.168.100.144
bind {PODIP}
#最大内存
maxmemory 2g
#开启集群模式
cluster-enabled yes   
#节点配置文件
cluster-config-file nodes-6397.conf
#集群节点超时时间(单位:毫秒)
cluster-node-timeout 15000
#集群是否需要所有的slot都分配给在线节点,才能正常访问
cluster-require-full-coverage no
#工作目录(aof、rdb、日志文件)
dir /data
#tcp-backlog
tcp-backlog 511
#客户端闲置多少秒后关闭连接(单位:秒)
timeout 300
#检测TCP连接活性的周期(单位:秒)
tcp-keepalive 60
#redis密码
requirepass test123
masterauth test123
#日志级别
loglevel notice
#日志记录目录
logfile "redis-6397.log"
#可用的数据库数
databases 16
#RDB保存条件
save 900 1
save 300 10
save 60 10000
#bgsave执行错误,是否停止Redis接受请求
stop-writes-on-bgsave-error no
#RDB文件是否压缩
rdbcompression yes
#RDB文件是否使用校验和
rdbchecksum yes
#RDB文件名
dbfilename dump-6397.rdb
#当从节点与主节点连接中断时,如果此参数值设置为“yes”,从节点可以继续处理客户端的
#请求。否则除info和slaveof命令之外,拒绝的所有请求并统一回复"SYNC with master in #progress"
slave-serve-stale-data yes
#从节点是否开启只读模式,集群架构下从节点默认读写都不可用,需要调用readyonly命令#开启只读模式
slave-read-only yes
#是否开启无盘复制
repl-diskless-sync no
#开启无盘复制后,需要延迟多少秒后进行创建RDB操作,一般用于同时加入多个从节点时,#保证多个从节点可共享RDB
repl-diskless-sync-delay 5
#是否开启主从复制socket的NO_DELAY选项:yes:Redis会合并小的TCP包来节省带宽,但##是这样增加同步延迟,造成主#从数据不一致;no:主节点会立即发送同步数据,没有延迟
repl-disable-tcp-nodelay no
#从节点的优先级
slave-priority 100
#是否开启AOF持久化模式
appendonly no
#Lua脚本“超时时间”(单位:毫秒)
lua-time-limit 5000
#慢查询被记录的阀值(单位微秒)
slowlog-log-slower-than 10000
#最多记录慢查询的条数
slowlog-max-len 1000
#Redis服务内存延迟监控
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-entries 512
list-max-ziplist-value 64
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
#是否激活重置哈希
activerehashing yes
#客户端输出缓冲区限制
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 512mb 128mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
#复制积压缓存区大小
repl-backlog-size 256mb
#redis server执行后台任务的频率,默认为10
hz 10
#最大客户端连接数
maxclients 15000

使用以下命令创建configmaps

kubectl create cm redis-test-conf --from-file=redis.conf=redis-test.conf

创建redis实例

将以下yaml内容保存到redis-sts.yaml中:

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: redis-test
  namespace: default
spec:
  podManagementPolicy: OrderedReady
  replicas: 10
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      name: redis-test
  serviceName: redis-test
  template:
    metadata:
      labels:
        name: redis-test
    spec:
      containers:
      - command:
        - sh
        - -c
        - cp /config/redis.conf /data/; sed -i "s?{PODIP}?${PODIP}?g" /data/redis.conf ;redis-server /data/redis.conf
        image: redis:4.0.7
        env:
        - name: PODIP
          valueFrom:
            fieldRef:
              apiVersion: v1
              fieldPath: status.podIP
        imagePullPolicy: IfNotPresent
        name: redis
        ports:
        - containerPort: 6379
          name: redis
          protocol: TCP
        resources: {}
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        volumeMounts:
        - mountPath: /config
          name: redis-config
       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值