前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >docker部署redis哨兵集群_redis部署安装

docker部署redis哨兵集群_redis部署安装

作者头像
全栈程序员站长
发布2022-11-02 16:40:40
5260
发布2022-11-02 16:40:40
举报

Docker 安装

Docker 部署redis

docker hub 上可以看到有redis 的官方镜像

在这里插入图片描述
在这里插入图片描述

不去网站,也可以通过如下命令查看有那些镜像可用 Docker search 命令

代码语言:javascript
复制
docker search redis 
在这里插入图片描述
在这里插入图片描述

拉取redis镜像

Docker pull 命令 这里我们拉取官方的最新版本的镜像:

代码语言:javascript
复制
docker pull redis:latest
在这里插入图片描述
在这里插入图片描述

查看本地镜像

Docker images 命令 有redis 和 hello-world

在这里插入图片描述
在这里插入图片描述

运行容器

Docker run 命令

代码语言:javascript
复制
docker run -itd --name redis-test -p 6379:6379 redis

-p 6379:6379:映射容器服务的 6379 端口到宿主机的 6379 端口。外部可以直接通过宿主机ip:6379 访问到 Redis 的服务

-itd 是docker run 的参数,等价于 -i -t -d 的结合,具体说明可以docker run –help 查看

在这里插入图片描述
在这里插入图片描述

查看容器运行信息

Docker ps 命令

代码语言:javascript
复制
docker ps
在这里插入图片描述
在这里插入图片描述

接着我们通过 redis-cli (redis 客户端)连接测试使用 redis 服务。 Docker exec 命令

代码语言:javascript
复制
docker exec -it redis-test /bin/bash

ctrl-c 停止运行redis-cli exit 退出docker exec

在这里插入图片描述
在这里插入图片描述

服务器本地可以访问使用了

redis配置文件设置

因为容器实例的运行是有生命周期的,所以一些redis的备份、日志和配置文件什么的最好还是放在服务器本地。这样当容器删除时,我们也可以保留备份和日志文件。

redis中文官方网站 下载一个redis ,从中获取原装的redis.conf 配置文件

在这里插入图片描述
在这里插入图片描述

配置文件涉及内容(有些是默认的,谨做个介绍,有的需要自己修改配置文件)

基本修改

代码语言:javascript
复制
bind 127.0.0.1            #注释掉这部分,使redis可以外部访问
requirepass               #给redis设置密码
logfile /data/redis.log    # 指定日志文件
protected-mode no   #关闭保护模式

RDB配置文件

代码语言:javascript
复制
# 设置 RDB 文件名和文件路径
dbfilename dump.rdb  (这个是默认的)
dir /data        (我从 ./改成了  /data)
----------------------------------------------------------------------(下面的不用修改)
# RDB 默认的设置 ,可以按照如下规则,根据自己的实际请求压力进行设置调整。
# 如果900秒内有1条Key信息发生变化,则进行快照;
save 900 1
#如果300秒内有10条Key信息发生变化,则进行快照;
save 300 10
#如果60秒内有10000条Key信息发生变化,则进行快照。
save 60 10000
# 启动备份文件压缩
rdbcompression yes
#redis 5之后,64位的CRC冗余校验码会放在RDB文件的末尾,以对文件完整性进行验证,但是在保存和加载RDB文件时,会损失10%左右的性能
rdbchecksum yes
# 如果持久化出错,主进程是否停止写入
stop-writes-on-bgsave-error yes

AOF配置文件

代码语言:javascript
复制
# 开启AOF 备份
appendonly yes
# AOF文件的保存位置和RDB文件的位置相同,都是通过dir参数设置的
dir /data
-----------------------------------------------(下面不用修改)
# AOF持久化的文件名,默认是appendonly.aof
appendfilename "appendonly.aof"
# 同步策略
# appendfsync always
appendfsync everysec
# appendfsync no
# aof重写期间是否同步
no-appendfsync-on-rewrite no
# 触发设置
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
# 加载aof出错如何处理
aof-load-truncated yes
# 文件重写策略
aof-rewrite-incremental-fsync yes

redis4.0相对与3.X版本其中一个比较大的变化是4.0添加了新的混合持久化方式。配置文件中修改成yes

代码语言:javascript
复制
aof-use-rdb-preamble yes

通过xftp工具将redis.conf配置文件移动到服务器指定文件夹下面

在这里插入图片描述
在这里插入图片描述

redis再启动

先把以前的那个运行的容器实例给停掉

代码语言:javascript
复制
docker stop redis-test  #  容器实例名或者容器ID均可
在这里插入图片描述
在这里插入图片描述

重新启动docker

代码语言:javascript
复制
systemctl restart docker

再run我们的redis 容器实例

代码语言:javascript
复制
docker run -itd --name redis -p 6379:6379 \
--restart=always \
-v /home/xt/redis/redis.conf:/etc/redis/redis.conf \
-v /home/xt/redis/data:/data \
redis redis-server /etc/redis/redis.conf 

-p 6379:6379:把容器内的6379端口映射到宿主机6379端口 –restart=always:启动docker时启动该容器 -v /home/xt/redis/redis.conf:/etc/redis/redis.conf:把宿主机配置好的redis.conf放到容器内的这个位置中 -v /home/xt/redis/data:/data:把redis持久化的数据在宿主机内显示,做数据备份 redis-server /etc/redis/redis.conf:按照这个redis.conf的配置启动

启动成功

在这里插入图片描述
在这里插入图片描述

Docker logs 命令 查看docker的日志

代码语言:javascript
复制
docker logs redis
在这里插入图片描述
在这里插入图片描述

服务器防火墙设置

ConterOS7.0以上使用的是firewall,ConterOS7.0以下使用的是iptables,我这里使用firewall 防火墙

查看firewall服务状态

代码语言:javascript
复制
systemctl status firewalld
在这里插入图片描述
在这里插入图片描述

开启防火墙服务

代码语言:javascript
复制
service firewalld start

然后再查看,防火墙运行状态变为running

在这里插入图片描述
在这里插入图片描述

查询redis 6379端口是否开放

firwall-cmd:是Linux提供的操作firewall的一个工具

代码语言:javascript
复制
firewall-cmd --query-port=6379/tcp
在这里插入图片描述
在这里插入图片描述

对外开放这个端口

代码语言:javascript
复制
firewall-cmd --permanent --add-port=6379/tcp

重启防火墙(修改配置后要重启防火墙)

代码语言:javascript
复制
firewall-cmd --reload

再次查询已经变为yes

在这里插入图片描述
在这里插入图片描述

如果是阿里云,还需要在安全组里面手动添加6379 端口 ,配置可由那些IP访问。不然你防火墙开放了端口也是没用的(亲身经历)。

在这里插入图片描述
在这里插入图片描述

redis可视化客户端GitHub下载 填写服务器的ip和端口,还有redis设置的密码,然后确定

在这里插入图片描述
在这里插入图片描述

如图所示,连接成功

在这里插入图片描述
在这里插入图片描述

References:

  1. https://www.runoob.com/docker/docker-install-redis.html
  2. https://blog.csdn.net/weixin_36074841/article/details/116604789
  3. https://truedei.blog.csdn.net/article/details/106418353?spm=1001.2101.3001.6650.2&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-2.highlightwordscore&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-2.highlightwordscore

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

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/180549.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月18日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Docker 部署redis
    • 拉取redis镜像
      • 查看本地镜像
        • 运行容器
          • 查看容器运行信息
          • redis配置文件设置
            • 基本修改
              • RDB配置文件
                • AOF配置文件
                  • redis再启动
                  • 服务器防火墙设置
                    • 查看firewall服务状态
                      • 开启防火墙服务
                        • 查询redis 6379端口是否开放
                        • References:
                        相关产品与服务
                        云数据库 Redis
                        腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
                        领券
                        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档