Redis 安装和配置

如果用 Spring Data Redis 依赖需注意

    • 查看锚点为:New in Spring Data Redis 的内容
  • 目前 201712 支持 Redis 3.2

如果用 RedisDesktopManager 客户端需注意

Docker 下安装 Redis

  • 创建一个宿主机目录用来存放 redis 配置文件:mkdir -p /data/docker/redis/conf
  • 创建一个宿主机以后用来存放数据的目录:mkdir -p /data/docker/redis/db
  • 赋权:chmod 777 -R /data/docker/redis
  • 自己编写一个配置文件 vim /data/docker/redis/conf/redis.conf,内容如下:
  • Redis 默认的配置文件内容:

安全情况的几个特殊配置:

bind 127.0.0.1

requirepass adgredis123456

protected-mode yes

 

免密情况:

bind 0.0.0.0

protected-mode no

 

其他:

port 6379

tcp-backlog 511

timeout 0

tcp-keepalive 300

daemonize no

supervised no

pidfile /data/redis_6379.pid

loglevel notice

logfile ""

databases 16

save 900 1

save 300 10

save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir /data

slave-serve-stale-data yes

slave-read-only yes

repl-diskless-sync no

repl-diskless-sync-delay 5

repl-disable-tcp-nodelay no

slave-priority 100

appendonly no

appendfilename "appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb

aof-load-truncated yes

lua-time-limit 5000

slowlog-log-slower-than 10000

slowlog-max-len 128

latency-monitor-threshold 0

notify-keyspace-events ""

hash-max-ziplist-entries 512

hash-max-ziplist-value 64

list-max-ziplist-size -2

list-compress-depth 0

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 256mb 64mb 60

client-output-buffer-limit pubsub 32mb 8mb 60

hz 10

aof-rewrite-incremental-fsync yes

  • 启动镜像:docker run -d -ti -p 6379:6379 -v /data/docker/redis/conf/redis.conf:/etc/redis/redis.conf -v /data/docker/redis/db:/data --restart always --name cloud-redis redis:3.2 redis-server /etc/redis/redis.conf
  • 查看镜像运行情况:docker ps
  • 进入镜像中 redis shell 交互界面:docker exec -it cloud-redis redis-cli -h 127.0.0.1 -p 6379 -a adgredis123456
  • 重新启动服务:docker restart cloud-redis

RedisCluster 集群(Docker 方式)

Redis 容器准备

 

创建 Cluster 集群(通过 redis-trib.rb)

 

# 是否以后台daemon方式运行,默认是 no,一般我们会改为 yes

daemonize no

pidfile /var/run/redis.pid

port 6379

tcp-backlog 511

timeout 0

tcp-keepalive 0

loglevel notice

logfile ""

# 开启数据库的数量,Redis 是有数据库概念的,默认是 16 个,数字从 0 ~ 15

databases 16

save 900 1

save 300 10

save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir ./

slave-serve-stale-data yes

slave-read-only yes

repl-diskless-sync no

repl-diskless-sync-delay 5

repl-disable-tcp-nodelay no

slave-priority 100

appendonly no

appendfilename "appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb

aof-load-truncated yes

lua-time-limit 5000

slowlog-log-slower-than 10000

slowlog-max-len 128

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 256mb 64mb 60

client-output-buffer-limit pubsub 32mb 8mb 60

hz 10

aof-rewrite-incremental-fsync yes

Redis-3.2.8 配置

 

# 默认绑定是:127.0.0.1,这样就只能本机才能连上,为了让所有机子连上,这里需要改为:0.0.0.0

bind 0.0.0.0

protected-mode yes

port 6379

tcp-backlog 511

timeout 0

tcp-keepalive 300

daemonize yes

supervised no

pidfile /var/run/redis_6379.pid

loglevel notice

logfile ""

databases 16

save 900 1

save 300 10

save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir ./

slave-serve-stale-data yes

slave-read-only yes

repl-diskless-sync no

repl-diskless-sync-delay 5

repl-disable-tcp-nodelay no

slave-priority 100

appendonly no

appendfilename "appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb

aof-load-truncated yes

lua-time-limit 5000

slowlog-log-slower-than 10000

slowlog-max-len 128

latency-monitor-threshold 0

notify-keyspace-events ""

hash-max-ziplist-entries 512

hash-max-ziplist-value 64

list-max-ziplist-size -2

list-compress-depth 0

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 256mb 64mb 60

client-output-buffer-limit pubsub 32mb 8mb 60

hz 10

aof-rewrite-incremental-fsync yes

设置 Redis 请求密码

 

Redis 常用命令

 

把 redis 添加到系统服务中

 

#!/bin/sh  

#  

# redis - this script starts and stops the redis-server daemon  

#  

# chkconfig:   - 85 15  

# description:  Redis is a persistent key-value database  

# processname: redis-server  

# config:      /usr/local/redis-2.4.X/bin/redis-server  

# config:      /usr/local/ /redis-2.4.X/etc/redis.conf  

# Source function library.  

. /etc/rc.d/init.d/functions  

# Source networking configuration.  

. /etc/sysconfig/network  

# Check that networking is up.  

[ "$NETWORKING" = "no" ] && exit 0  

redis="/usr/local/bin/redis-server" 

prog=$(basename $redis)  

REDIS_CONF_FILE="/etc/redis.conf" 

[ -f /etc/sysconfig/redis ] && . /etc/sysconfig/redis  

lockfile=/var/lock/subsys/redis  

start() {  

    [ -x $redis ] || exit 5  

    [ -f $REDIS_CONF_FILE ] || exit 6  

    echo -n $"Starting $prog: "  

    daemon $redis $REDIS_CONF_FILE  

    retval=$?  

    echo  

    [ $retval -eq 0 ] && touch $lockfile  

    return $retval  

}  

stop() {  

    echo -n $"Stopping $prog: "  

    killproc $prog -QUIT  

    retval=$?  

    echo  

    [ $retval -eq 0 ] && rm -f $lockfile  

    return $retval  

}  

restart() {  

    stop  

    start  

}  

reload() {  

    echo -n $"Reloading $prog: "  

    killproc $redis -HUP  

    RETVAL=$?  

    echo  

}  

force_reload() {  

    restart  

}  

rh_status() {  

    status $prog  

}  

rh_status_q() {  

    rh_status >/dev/null 2>&1  

}  

case "$1" in  

    start)  

        rh_status_q && exit 0  

        $1  

        ;;  

    stop)  

        rh_status_q || exit 0  

        $1  

        ;;  

    restart|configtest)  

        $1  

        ;;  

    reload)  

        rh_status_q || exit 7  

        $1  

        ;;  

    force-reload)  

        force_reload  

        ;;  

    status)  

        rh_status  

        ;;  

    condrestart|try-restart)  

        rh_status_q || exit 0  

    ;;  

    *)  

        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart| reload|orce-reload}"  

        exit 2  

esac

 

Redis 客户端

 

Redis GUI 管理工具

  • 目标:3 主 3 从(一般都是推荐奇数个 master)
  • 最小集群数推荐是:3
  • 测试机的最低配置推荐是:2C4G
  • 拉取镜像:docker pull registry.cn-shenzhen.aliyuncs.com/youmeek/redis-to-cluster:3.2.3
  • 重新打个 tag(旧名字太长了):docker tag registry.cn-shenzhen.aliyuncs.com/youmeek/redis-to-cluster:3.2.3 redis-to-cluster:3.2.3
  • 创建网段:docker network create --subnet=172.19.0.0/16 net-redis-to-cluster
  • 宿主机创建配置文件:mkdir -p /data/docker/redis-to-cluster/config && vim /data/docker/redis-to-cluster/config/redis.conf
  • bind 0.0.0.0
    protected-mode yes
    port 6379
    tcp-backlog 511
    timeout 0
    tcp-keepalive 300
    daemonize yes
    supervised no
    pidfile /var/run/redis_6379.pid
    loglevel notice
    logfile ""
    databases 16
    save 900 1
    save 300 10
    save 60 10000
    stop-writes-on-bgsave-error yes
    rdbcompression yes
    rdbchecksum yes
    dbfilename dump.rdb
    dir ./
    slave-serve-stale-data yes
    slave-read-only yes
    repl-diskless-sync no
    repl-diskless-sync-delay 5
    repl-disable-tcp-nodelay no
    slave-priority 100
    appendonly yes
    appendfilename "appendonly.aof"
    appendfsync everysec
    no-appendfsync-on-rewrite no
    auto-aof-rewrite-percentage 100
    auto-aof-rewrite-min-size 64mb
    aof-load-truncated yes
    lua-time-limit 5000
    cluster-enabled yes
    cluster-config-file nodes-6379.conf
    cluster-node-timeout 15000
    slowlog-log-slower-than 10000
    slowlog-max-len 128
    latency-monitor-threshold 0
    notify-keyspace-events ""
    hash-max-ziplist-entries 512
    hash-max-ziplist-value 64
    list-max-ziplist-size -2
    list-compress-depth 0
    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 256mb 64mb 60
    client-output-buffer-limit pubsub 32mb 8mb 60
    hz 10
    aof-rewrite-incremental-fsync yes

     

  • 赋权:chmod 777 -R /data/docker/redis-to-cluster/
  • 运行 6 个节点:
    • docker run -it -d --name redis-to-cluster-1 -p 5001:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.2 redis-to-cluster:3.2.3 bash
    • docker run -it -d --name redis-to-cluster-2 -p 5002:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.3 redis-to-cluster:3.2.3 bash
    • docker run -it -d --name redis-to-cluster-3 -p 5003:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.4 redis-to-cluster:3.2.3 bash
    • docker run -it -d --name redis-to-cluster-4 -p 5004:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.5 redis-to-cluster:3.2.3 bash
    • docker run -it -d --name redis-to-cluster-5 -p 5005:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.6 redis-to-cluster:3.2.3 bash
    • docker run -it -d --name redis-to-cluster-6 -p 5006:6379 -v /data/docker/redis-to-cluster/config/redis.conf:/usr/redis/redis.conf --net=net-redis-to-cluster --ip 172.19.0.7 redis-to-cluster:3.2.3 bash
  • 配置 redis-to-cluster-1 节点:docker exec -it redis-to-cluster-1 bash
    • 启动容器的 redis:/usr/redis/src/redis-server /usr/redis/redis.conf
  • 其他 5 个节点一样进行启动。
  • 配置 redis-to-cluster-1 节点(或者选择其他任意一个节点):docker exec -it redis-to-cluster-1 bash
  • mkdir -p /usr/redis/cluster
  • cp /usr/redis/src/redis-trib.rb /usr/redis/cluster/
  • cd /usr/redis/cluster/
  • 创建 Cluster 集群(会有交互)(镜像中已经安装了 ruby 了):./redis-trib.rb create --replicas 1 172.19.0.2:6379 172.19.0.3:6379 172.19.0.4:6379 172.19.0.5:6379 172.19.0.6:6379 172.19.0.7:6379
    • --replicas 1 表示为每个主节点创建一个从节点
    • 如果正常的话,会出现下面内容:
  • >>> Creating cluster
    >>> Performing hash slots allocation on 6 nodes...
    Using 3 masters:
    172.19.0.2:6379
    172.19.0.3:6379
    172.19.0.4:6379
    Adding replica 172.19.0.5:6379 to 172.19.0.2:6379
    Adding replica 172.19.0.6:6379 to 172.19.0.3:6379
    Adding replica 172.19.0.7:6379 to 172.19.0.4:6379
    M: 9c1c64b18bfc2a0586be2089f13c330787c1f67b 172.19.0.2:6379
       slots:0-5460 (5461 slots) master
    M: 35a633853329c9ff25bb93a7ce9192699c2ab6a8 172.19.0.3:6379
       slots:5461-10922 (5462 slots) master
    M: 8ea2bfeeeda939abb43e96a95a990bcc55c10389 172.19.0.4:6379
       slots:10923-16383 (5461 slots) master
    S: 9cb00acba065120ea96834f4352c72bb50aa37ac 172.19.0.5:6379
       replicates 9c1c64b18bfc2a0586be2089f13c330787c1f67b
    S: 8e2a4bb11e97adf28427091a621dbbed66c61001 172.19.0.6:6379
       replicates 35a633853329c9ff25bb93a7ce9192699c2ab6a8
    S: 5d0fe968559af3035d8d64ab598f2841e5f3a059 172.19.0.7:6379
       replicates 8ea2bfeeeda939abb43e96a95a990bcc55c10389
    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 172.19.0.2:6379)
    M: 9c1c64b18bfc2a0586be2089f13c330787c1f67b 172.19.0.2:6379
       slots:0-5460 (5461 slots) master
    M: 35a633853329c9ff25bb93a7ce9192699c2ab6a8 172.19.0.3:6379
       slots:5461-10922 (5462 slots) master
    M: 8ea2bfeeeda939abb43e96a95a990bcc55c10389 172.19.0.4:6379
       slots:10923-16383 (5461 slots) master
    M: 9cb00acba065120ea96834f4352c72bb50aa37ac 172.19.0.5:6379
       slots: (0 slots) master
       replicates 9c1c64b18bfc2a0586be2089f13c330787c1f67b
    M: 8e2a4bb11e97adf28427091a621dbbed66c61001 172.19.0.6:6379
       slots: (0 slots) master
       replicates 35a633853329c9ff25bb93a7ce9192699c2ab6a8
    M: 5d0fe968559af3035d8d64ab598f2841e5f3a059 172.19.0.7:6379
       slots: (0 slots) master
       replicates 8ea2bfeeeda939abb43e96a95a990bcc55c10389
    [OK] All nodes agree about slots configuration.
    >>> Check for open slots...
    >>> Check slots coverage...
    [OK] All 16384 slots covered.

     

  • 连接集群测试:
    • 进入随便一个节点:docker exec -it redis-to-cluster-1 bash
    • /usr/redis/src/redis-cli -c
    • 查看集群情况:cluster nodes
    • 写入数据:set myKey myValue,如果成功会返回:Redirected to slot [16281] located at 172.19.0.4:6379,可以推断它是 redis-to-cluster-3 容器
    • 暂定掉 redis-to-cluster-3 容器:docker pause redis-to-cluster-3
    • 重新连接:/usr/redis/src/redis-cli -c
    • 查看集群情况:cluster nodes
    • 获取值:get myKey
    • 重新启动 redis-to-cluster-3:docker unpause redis-to-cluster-3
    • 查看集群情况:cluster nodes
  • Spring Boot 项目 Docker 容器访问 RedisCluster
    • application.yml 配置的 IP 地址:172.19.0.2 等
    • docker 容器启动增加 --net=host 使用宿主机网络
  • Redis 编译安装

  • Redis 安装
      • 安装依赖包:yum install -y gcc-c++ tcl
      • 解压:tar zxvf redis-3.0.7.tar.gz
      • 进入解压后目录:cd /usr/local/redis-3.0.7/
      • 编译:make
      • 编译安装:make install
        • 安装完之后会在:/usr/local/bin 目录下生成好几个 redis 相关的文件
      • 复制配置文件:cp /usr/local/redis-3.0.7/redis.conf /etc/
      • 修改配置:vim /etc/redis.conf
        • 把旧值:daemonize no
        • 改为新值:daemonize yes
      • 启动:/usr/local/bin/redis-server /etc/redis.conf
      • 关闭:redis-cli -h 127.0.0.1 -p 6379 shutdown
      • 关闭(带密码):redis-cli -h 127.0.0.1 -p 6379 -a 123456 shutdown
      • 查看是否启动:ps -ef | grep redis
      • 进入客户端:redis-cli
      • 关闭客户端:redis-cli shutdown
      • 开机启动配置:echo "/usr/local/bin/redis-server /etc/redis.conf" >> /etc/rc.local
      • 开放防火墙端口:
        • 添加规则:iptables -I INPUT -p tcp -m tcp --dport 6379 -j ACCEPT
        • 保存规则:service iptables save
        • 重启 iptables:service iptables restart
  • Redis-3.0.7 配置

  • 编辑配置文件:vim /etc/redis.conf
  • Redis 默认的配置文件内容:
  • 编辑配置文件:vim /etc/redis.conf
  • Redis 默认的配置文件内容:
  • 打开 vim /etc/redis.conf 配置文件,找到默认是被注释的这一行:# requirepass foobared
  • 去掉注释,把 foobared 改为你想要设置的密码,比如我打算设置为:123456,所以我改为:requirepass 123456
  • 修改之后重启下服务
  • 有了密码之后,进入客户端,就得这样访问:redis-cli -h 127.0.0.1 -p 6379 -a 123456
  • 如果用 IP 进入客户端,但是报:Could not connect to Redis at 192.168.1.121:6379: Connection refused
    • 原因:Redis 默认只允许本机访问,可是有时候我们也需要 Redis 被远程访问。
    • 解决办法:
      • 修改 Redis 配置文件:vim /etc/redis.conf        - 找到 bind 那行配置,默认是(需要注意的是配置文件中除了注释还有一个默认开启的地方,所以不要漏掉):# bind 127.0.0.1
      • 去掉 # 注释并改为:bind 0.0.0.0
  • 命令是不区分大小写的,但是这里为了方便和后面的 key value 进行区分所以我全部写大写,你也可以用小写。
    • 但是需要注意的是:key 是完全区分大小写的,比如 key=codeBlog 和 key=codeblog 是两个键值
  • 官网命令列表:http://redis.io/commands
  • SET key value,设值。eg:SET myblog www.youmeek.com
  • GET key,取值
  • SELECT 0,切换数据库
  • INCR key,递增数字
  • DECR key,递减数字
  • KEYS *,查看当前数据库下所有的 key
  • APPEND key value,给尾部追加内容,如果要追加的 key 不存在,则相当于 SET key value
  • STRLEN key,返回键值的长度,如果键不存在则返回 0
  • MSET key1 value1 key2 value2,同时设置多值
  • MGET key1 value1 key2 value2,同时取多值
  • EXPIRE key 27,设置指定键的生存时间,27 的单位是秒
  • TTL key,查看键的剩余生存时间
    • 返回 -2,表示不存在,过了生存时间后被删除
    • 返回 -1,表示没有生存时间,永久存储
    • 返回正整数,表示还剩下对应的生存时间
  • PERSIST key,清除生成时间,重新变成永久存储(重新设置 key 的值也可以起到清除生存时间的效果)
  • FLUSHDB,清空当前数据库所有键值
  • FLUSHALL,清空所有数据库的所有键值
  • 新建文件:vim /etc/init.d/redis
  • 添加如下内容:
  • 修改权限:chmod 755 /etc/init.d/redis
  • 启动服务:service redis start
  • 停止服务:service redis stop
  • 重启服务:service ngredisnx restart
  • Java:http://redis.io/clients#java
  • Redis Desktop Manager
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值