5.Redis 一篇就够

5.1 单机

文档地址 https://blog.csdn.net/qq_30764991/article/details/81564652

安装redis需要c语言的编译环境

yum install gcc-c++

解压

tar -xvf redis-5.0.5.tar.gz

mv redis-5.0.5 redis

编译

cd redis

make

图片12.png

安装

make install PREFIX=/home/redis

图片13.png

到安装目录启动

cd /home/redis/bin

./redis-server

图片14.png

复制配置文件

cp /home/software/redis/redis.conf /home/redis/bin/

修改守护进程为yes

vi redis.conf

设置行码

:set nu

69 改为0.0.0.0

136 改为yes

图片15.png

启动

./redis-server redis.conf

查看

ps aux|grep redis

客户端

./redis-cli

设置密码:

在/home/redis/bin目录下执行 ./redis-cli 进入redis客户端

查询redis密码:config get requirepass

设置redis密码为root: config set requirepass root

认证登陆redis: auth root

图片16.png

5.2 redis自启动

touch /usr/lib/systemd/system/redis.service

chown prometheus2:prometheus2 /usr/lib/systemd/system/redis.service

chown -R prometheus2:prometheus2 /home/redis

vim /usr/lib/systemd/system/redis.service

[Unit]

Description=redis

After=network.target

[Service]

Type=forking

User=prometheus2

ExecStart=/home/redis/bin/redis-server /home/redis/bin/redis.conf

Restart=on-failure

[Install]

WantedBy=multi-user.target

启动

systemctl daemon-reload

systemctl enable redis.service

systemctl start redis.service

systemctl status redis.service

systemctl stop redis.service

systemctl restart redis.service

5.3 redis config

单位 不区分大小写

image.png

包含

image.png

网络 NETWORK

bind 127.0.0.1 #绑定

image.png

端口

image.png

保护模式

image.png

通用

daemonize yes #以守护进程模式进行

pidfile /var/run/redis_6379.pid #指定进程文件

日志级别

image.png

日志文件输出地址

image.png

logfile ''/home/logs/redis/reids.log''

databases 16 默认数据库数量

always-show-logo yes 是否显示logo

快照 SNAPSHOTTING

持久化 在规定时间内 执行了多少次操作 会持久化到.rdb .aof文件

redis是内存数据库 不持久化 数据会丢失

save 900 1 #90s内至少有一个key进行修改 我们会进行持久化

save 300 10 #300s内至少有10个key进行修改 我们会进行持久化

save 60 10000 #60s内至少有10000个key进行修改 我们会进行持久化

save 10 10000 #10s内至少有10000个key进行修改 我们会进行持久化

stop-writes-on-bgsave-error no # 持久化失败是否继续工作 yes 是

rdbcompression yes #是否压缩rdb文件

rdbchecksum yes #保存rdb文件时 是否进行错误检查校验

dir ./ #rdb 文件保存目录

REPLICATION 负责 主从复制

SECURITY 安全

requirepass root #设置密码为root

CLIENTS 客户端

maxclients 10000 #最大客户端数为10000

MEMORY MANAGEMENT 内存管理

maxmemory #最大内存数 5G 5368709120

maxmemory-policy noeviction #达到最大内存时的 策略

1、volatile-lru:只对设置了过期时间的key进行LRU(默认值)

2、allkeys-lru :删除lru算法的key

3、volatile-random:随机删除即将过期key

4、allkeys-random:随机删除

5、volatile-ttl :删除即将过期的

6、noeviction :永不过期,返回错误

APPEND ONLY MODE aof配置

appendonly no #默认关闭 大多数情况下 rdb完全够用

appendfilename "appendonly.aof" #文件存储名称

appendfsync always #每次修改同步

appendfsync everysec #每秒执行一次 可能丢失一秒的数据

appendfsync no #不同步 操作系统自动同步 最快

5.4 主从同步 读写分离

x.x.x.2 master 2G ABCabc123

x.x.x.3 slave 2G ABCabc123

x.x.x.6 slave 2G ABCabc123

①查看信息

./redis-cli info replication #查看当前库信息

Replication

role:master

connected_slaves:0 #从库为0

master_replid:b7e98c58ca40eb3cfc842bb89698172162e1aa60

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:0

second_repl_offset:-1

repl_backlog_active:0

repl_backlog_size:1048576

repl_backlog_first_byte_offset:0

repl_backlog_histlen:0

②配置主从关系 认主

slaveof x.x.x.6 6379

[图片上传失败...(image-c3fc31-1655779504259)]

③配置后信息

Replication

role:master

connected_slaves:2

slave0:ip=x.x.x.3,port=6379,state=online,offset=127645169,lag=0

slave1:ip=x.x.x.6,port=6379,state=online,offset=127935404,lag=0

master_replid:4804c72f789afab9b9f1819df933ae74f256e503

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:128106631

second_repl_offset:-1

repl_backlog_active:1

repl_backlog_size:1048576

repl_backlog_first_byte_offset:127058056

repl_backlog_histlen:1048576

Replication

role:slave

master_host:x.x.x.2

master_port:6379

master_link_status:up

master_last_io_seconds_ago:0

master_sync_in_progress:0

slave_repl_offset:88091145

slave_priority:100

slave_read_only:1

connected_slaves:0

master_replid:4804c72f789afab9b9f1819df933ae74f256e503

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:88091145

second_repl_offset:-1

repl_backlog_active:1

repl_backlog_size:1048576

repl_backlog_first_byte_offset:87042570

repl_backlog_histlen:1048576

主机可以读写 从机只能读 主机宕机后 从机不能主动变成主机

命令行配置当次运行有效 重启后无效

5.5 多哨兵sentinel

①查看sentinel.config

cat sentinel.conf | grep -v "#" | grep -v "^$"

复制一份

cat sentinel.conf | grep -v "#" | grep -v "^$" >/usr/local/redis/bin/sentinel.conf

②配置哨兵文件 sentinel.config

port 26379

daemonize yes

pidfile /home/redis/redis-sentinel.pid

logfile "/home/redis/redis-sentinel.log"

dir /home/redis

sentinel monitor mymaster x.x.x.2 6379 2

sentine1 auth-pass mymaster root

sentinel down-after-milliseconds mymaster 30000

sentinel parallel-syncs mymaster 1

sentinel failover-timeout mymaster 180000

sentinel deny-scripts-reconfig yes

③运行哨兵

./redis-sentinel sentinel.conf

④成功效果

./redis-cli -p 26379 info

image.png
image.png

5.6 sentinel自启动

touch /usr/lib/systemd/system/redis_sentinel.service

chown prometheus2:prometheus2 /usr/lib/systemd/system/redis_sentinel.service

chown -R prometheus2:prometheus2 /home/redis

vim /usr/lib/systemd/system/redis_sentinel.service

[Unit]

Description=redis_sentinel

After=network.target

[Service]

Type=forking

User=prometheus2

ExecStart=/home/redis/bin/redis-sentinel /home/redis/bin/sentinel.conf

Restart=on-failure

[Install]

WantedBy=multi-user.target

启动

systemctl daemon-reload

systemctl enable redis_sentinel.service

systemctl start redis_sentinel.service

systemctl status redis_sentinel.service

systemctl stop redis_sentinel.service

systemctl restart redis_sentinel.service

5.7 SpringBoot整合redis集群

spring:

redis:

database: ${REDIS_BASEDATA:10}

password: ${REDIS_PASSWORD:root}

timeout: ${REDIS_TIMEOUT:86400}

cluster:

  nodes:

    - x.x.x.2:6379

    - x.x.x.3:6379

    - x.x.x.6:6379

sentinel:

  master: mymaster

  nodes:

    - x.x.x.2:26379

    - x.x.x.3:26379

    - x.x.x.6:26379

jedis:

  pool:

    max-active: 1000

    max-wait: -1

    max-idle: 10

    min-idle: 5

问题一:redis 6379端口不通解决方法

1.reids务器的6379端口telnet不通

image.png
  1. 查看reids进程和端口,都是存在的。只是ip地址是127.0.0.1而不是0.0.0.0,只是本机能使用

一般我们在服务端绑定端口的时候可以选择绑定到0.0.0.0,这样我的服务访问方就可以通过我的多个ip地址访问我的服务

image.png

3.查找redis的配置文件redis.conf 使用命令:find / -name redis.conf

image.png

4.查找bind 127.0.0.1所在的行数

使用命令:cat /home/redis/bin/redis.conf|grep bin -n

image.png

5.在vi下 set nu 显示行号 直接输入行数 调整

  1. 编辑配置文件vim /home/redis/bin/redis.conf

    bind 127.0.0.1修改为bind 0.0.0.0

image.png

7.重启redis-server (kill -9 PID 先杀掉之前的实例)

image.png
image.png

问题****二****:redis****写入缓慢

Redis大批量插入数据导致报

io.lettuce.core.RedisCommandExecutionException: MISCONF Redis is configured to save RDB snapshots错误

image.png
image.png

问题三:slave status=send_bulk

©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容