本地虚拟机centos7通过docker安装主从redis3.2

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 本地虚拟机centos7通过docker安装主从redis3.2

1、下载redis docker镜像

docker pull redis:3.2

2、在home下建立mydata目录

在/home/mydata/redis下面建立两个目录 conf与data

3、docker运行主从

docker run -p 6379:6379 --name masterredis -v /home/mydata/redis/data:/data -v /home/mydata/redis/conf/master.conf:/data/redis.conf --privileged=true -d redis:3.2 redis-server /data/redis.conf --requirepass "masterredis" --appendonly yes
docker run -p 6379:6379 --name slaveredis -v /home/mydata/redis/data:/data -v /home/mydata/redis/conf/slave.conf:/data/redis.conf --privileged=true -d redis:3.2 redis-server /data/redis.conf --requirepass "slaveredis" --appendonly yes

4、开放防火墙端口

firewall-cmd --add-port=6379/tcp --permanent
firewall-cmd --reload

5、运行测试

docker exec -it masterredis bash
redis-cli -a masterredis 客户端登录进入masterredis 可以 info replication 查询复制情况
redis-cli -a slaveredis

docker container update --restart=always 容器名字 增加一个容器的自动启动参数方法

刚开始slave redis老是连接不上,应该主要原因是没有加参数masterauth password

6、配置参数

总结redis master的参数主要有下面

daemonize no
pidfile "/var/run/redis.pid"
port 6379
timeout 300
loglevel warning
logfile "redis.log"
databases 1
rdbcompression yes
dbfilename "redis.rdb"
dir "/data"
requirepass password
masterauth password
maxclients 10000
maxmemory 1000mb
maxmemory-policy allkeys-lru
appendonly no
appendfsync alway

因为有些可以不需要,requirepass password启动的时候配置了,

总结redis slave的参数主要有下面

daemonize no
pidfile "/var/run/redis.pid"
port 6379
timeout 300
loglevel warning
logfile "redis.log"
databases 1
rdbcompression yes
dbfilename "redis.rdb"
dir "/data"
requirepass password
masterauth password
maxclients 10000
maxmemory 1000mb
maxmemory-policy allkeys-lru
appendonly no
appendfsync always
slaveof 192.168.199.151 6379

7、生产过程中要用的redis就要对redis的配置参数一一进行优化与配置了

同时生产应该采用哨兵模式,但这个应该要一主二从才行,一主一从应该选举就有问题

8、时间问题,可以这样操作

rm /etc/localtime
ln -sv /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

这样就变成中国上海时间了

但我的虚拟机主机与docker时间问题目前还没有解决

用下面解决在进入docker容器后

echo "Asia/shanghai" > /etc/timezone
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
20小时前
|
应用服务中间件 Docker Windows
windows基于Docker安装并启动Tomcat(解决404)
windows基于Docker安装并启动Tomcat(解决404)
11 1
|
16小时前
|
NoSQL Linux 网络安全
centos安装Redis
centos安装Redis
7 0
|
16小时前
|
应用服务中间件 nginx
centos7.6安装Nginx解决403
centos7.6安装Nginx解决403
4 0
|
16小时前
|
消息中间件 RocketMQ
Centos7.6安装RocketMQ4.9.2并配置开机自启
Centos7.6安装RocketMQ4.9.2并配置开机自启
5 0
|
16小时前
|
Java Linux Maven
Centos7.6安装Maven3.8.3并配置阿里云镜像
Centos7.6安装Maven3.8.3并配置阿里云镜像
6 0
|
17小时前
|
Linux
centos7安装maven3.8.1并配置阿里云镜像
centos7安装maven3.8.1并配置阿里云镜像
5 0
|
18小时前
|
Java Linux 开发工具
Centos安装java
Centos安装java
10 0
|
19小时前
|
云安全 关系型数据库 MySQL
Deepin安装docker使用mysql
Deepin安装docker使用mysql
10 0
|
8月前
|
SQL NoSQL Java
Redis学习---大数据技术之Redis(NoSQL简介、Redis简介、Redis安装、五大数据类型、相关配置、持久化)
Redis学习---大数据技术之Redis(NoSQL简介、Redis简介、Redis安装、五大数据类型、相关配置、持久化)
|
10月前
|
存储 消息中间件 缓存
Redis 学习 | Redis 初识与安装
Redis 学习 | Redis 初识与安装