Docker 安装

Docker 部署redis

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

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

docker search redis

拉取redis镜像

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

docker pull redis:latest

查看本地镜像

Docker images 命令
有redis 和 hello-world

运行容器

Docker run 命令

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 命令

docker ps


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

docker exec -it redis-test /bin/bash

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

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

redis配置文件设置

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

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

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

基本修改

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

RDB配置文件

# 设置 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配置文件

# 开启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

aof-use-rdb-preamble yes

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

redis再启动

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

docker stop redis-test  #  容器实例名或者容器ID均可


重新启动docker

systemctl restart docker

再run我们的redis 容器实例

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的日志

docker logs redis

服务器防火墙设置

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

查看firewall服务状态

systemctl status firewalld

开启防火墙服务

service firewalld start

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

查询redis 6379端口是否开放

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

firewall-cmd --query-port=6379/tcp


对外开放这个端口

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

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

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

Docker部署redis相关推荐

  1. 通过 Docker 部署 Redis 6.x 集群

    点击上方 好好学java ,选择 星标 公众号重磅资讯,干货,第一时间送达 今日推荐:推荐19个github超牛逼项目!个人原创100W +访问量博客:点击前往,查看更多 作者:超级小豆丁 http: ...

  2. docker部署redis集群_Docker部署Redis集群----第九节(docker-redis哨兵集群“轮询分流”篇实例一)...

    到此,我们的 Redis 哨兵集群就结束了,本篇章是第九篇章,也是使用集群方式的实例一来实现php的轮询分流. 1.准备工作: 在我们上一篇章实现redis 哨兵集群的基础上开始,在服务器上部署php ...

  3. Linux中Docker部署Redis

    应用背景:在Docker容器中部署Redis,并通过外部机器访问Redis 第一步:搜索Redis镜像 docker search redis 第二步:拉取Redis镜像 docker pull re ...

  4. Redis 集群搭建(三):Docker 部署 Redis + Sentinel 高可用集群

    Redis 集群搭建(三):Docker 部署 Redis + Sentinel 高可用集群 前言 建议 官方译文 什么是 Sentinel? Sentinel 优点 Redis 配置文件 maste ...

  5. 三小时,阿里云使用docker部署redis(阅文无数)

    相信大家肯定看了不少的使用阿里云通过docker部署redis的博文,但是这些博文的步骤确是模糊,最后很难成功. 第一步: 拉取redis镜像 docker pull redis # docker p ...

  6. 三台机器使用Docker部署Redis集群

    三台机器使用Docker部署Redis集群 我们这里采用Docker在三台服务器上面进行Redis集群的搭建,它方便快捷.容易上手. 1.集群原理 在Redis集群中,所以的节点彼此关联,节点内部通过 ...

  7. Docker部署Redis 图文教程

    快过年了,这里老王提前和大家说声新年快乐~ 年末项目收尾工作比较多,有段时间没有更新,今天和大家分享下使用docker部署redis,为大家在自己的服务器上做一些redis相关的功能开发时,提供服务支 ...

  8. Docker部署Redis容器

    从仓库下载镜像 sudo docker pull redis 创建容器(前提:将redis.conf文件放入到/Users/chengang/docker/redis目录里面) docker run ...

  9. Redis practise(二)使用Docker部署Redis高可用,分布式集群

    思路 鉴于之间学习过的Docker一些基础知识,这次准备部署一个简单的分布式,高可用的redis集群,如下的拓扑 tuopu.png 下面介绍下,对于这张拓扑图而言,需要了解的一些基础概念. Redi ...

最新文章

  1. 通过Maven命令将本地jar打到本地Maven仓库
  2. 什么是地理数据库geodatabase?
  3. Kaggle 官方教程:嵌入
  4. 快手活跃用户预测_哈工大团队解决方案
  5. 【译】你不知道的 Chrome 调试工具技巧 第二十三天:Drawer tips 后续
  6. Codeforces Round #567 (Div. 2)
  7. 9.数据结构 --- 查找
  8. QT学习-核心类列表-12、QtDesigner
  9. JS 一个简单的隔行变色函数
  10. 如何复制百度文库中的内容
  11. java 盲水印_3步搞定图像盲水印?试试云开发扩展能力
  12. RabbitMQ:四种ExChange用法
  13. gmx_MMPBSA--计算蛋白-配体自由能及能量分解
  14. 唤起高德app执行导航
  15. ssl证书过期怎么解决?
  16. 人工智能前沿技术应用趋势与发展展望
  17. 启动WIFI时:equest firmware failed with error 0xfffffffe ifconfig: SIOCSIFFLAGS: Operation not permitted
  18. 【elasticsearch】elasticsearch教程 es整合springboot教程 kibana安装教程 解决kibana访问404
  19. 【LSSVM分类】基于matlab遗传算法优化LSSVM烟叶识别【含Matlab源码 1944期】
  20. 计算机毕业设计JAVA课堂管理系统小程序用户端mybatis+源码+调试部署+系统+数据库+lw

热门文章

  1. 设计模式之略见一斑(Observer观察者模式)
  2. 机器人学:(1)机器人基础
  3. cmd编译java命令_使用CMD命令编译和运行Java程序
  4. 减肥该怎么吃?最全减肥食谱(附做法)
  5. CCF系列题解--2016年4月第四题 方格游戏
  6. 全国县及县以上行政区划代码信息类(C#.Net)
  7. 软件测试中语句覆盖的优点,软件测试之测试覆盖率的基本策略
  8. WPF Touch双击事件
  9. Unity2d_MapleStory自学记录
  10. 推荐10套高端投资公司官网模板Web源码下载(Bootstrap实现)