DockerFile创建一个redis容器的全过程

简介:

本次目标是用Centos 7的基础镜像做一个redis容器供开发人员在开发环境里蹂躏。


首先,创建一个叫redis-test的文件夹,在这个redis-test文件夹里建立一个Dockerfile,内容如下:

1
2
3
4
5
6
7
FROM centos:latest
MAINTAINER Chris Chan  "chenx1242@163.com"
ENV REFRESHED_AT 2017-02-16
RUN yum -y update &&  yum -y  install  epel-release && yum -y  install  redis && yum -y  install  net-tools
EXPOSE 6379
ENTRYPOINT [  "/usr/bin/redis-server"  ]
CMD []

这里我们简单说一下整个Dockerfile的内容:

首先选择了基础镜像是centos的最新版,即centos 7,然后填写作者信息;

在yum这一块要注意,如果没有安装epel-release的话,是无法正常安装redis的,这是centos与ubuntu不一样的地方。至于后面又补充安装了net-tools是因为centos 7里不自带ifconfig命令,所以需要安装一下net-tools,这样就有了ifconfig了;

随即我们又开放了6379端口;

然后就是entrypoint和cmd,这两个命令的区别很重要,具体区别请看:http://cloud.51cto.com/art/201411/457338.htm 这篇文章。


然后我们就可以依照这个Dockfile去建立一个镜像,因为目的是要在“centos环境下建立一个redis”,那么我们这个镜像的名字就叫作lccentos/redis,具体操作就是在redis-test文件夹下执行#docker build -t lccentos/redis .


然后根据这个镜像需要制作一个容器,容器的名字就叫redisforcentos,那么命令就是:#docker run -d -p 6379 --name redisforcentos lccentos/redis


然后我们#docker ps -a看一下效果。

wKioL1imopqwKls1AAA5_Wn8hvY175.png

可见宿主机的32774端口和容器的6379端口“融为一体”,这个时候,我们测试一下这个redisforcentos的容器是否已经正常启动了redis。

wKioL1impCGjd-C3AAAULI1m2HY604.png


而且对于Docker来说,可以多个docker对应宿主机的同一个端口,比如我这台机器搞了两个redis,两个容器都可以指向6379的端口,如图:

wKiom1ir50fAGR8gAABP9sTAKOA169.png

这里也说一下Dockerfile的优化原则:

1)ADD和VOLUME应该放在Dockerfile底部,因为它们相对比yum安装那些变化的更勤;

2)EXPOSE可以一口气对应多个端口,比如

EXPOSE 80 2003 2004 7002

的效果跟下面的效果一样;

EXPOSE 80 
EXPOSE 2003 
EXPOSE 2004 
EXPOSE 7002

3)ADD的操作应该放在Dockerfile的最下面;




参考资料:http://dockone.io/article/255?spm=5176.100239.blogcont40494.25.8RXqDX



 本文转自 苏幕遮618 51CTO博客,原文链接:http://blog.51cto.com/chenx1242/1898855


相关文章
|
NoSQL 关系型数据库 Redis
Docker的通俗理解和通过宿主机端口访问Redis容器的实例
本文目标:引导初学者入门Docker,理解镜像、容器和宿主机概念,学习常用Docker命令,特别是如何创建并从Redis容器通过宿主机端口访问。 关键点: - Docker核心:镜像(类)、容器(实例)、宿主机(运行环境)。 - `docker pull` 拉取镜像,如 `redis:3.0`。 - `docker run -d --name` 后台运行容器,如 `my-redis`。 - `-p` 参数做端口映射,如 `6379:6379`。 - `docker exec -it` 交互式进入容器,如 `bash` 或执行命令。
536 4
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
496 5
|
9月前
|
缓存 JavaScript 前端开发
Dockerfile全面指南:从基础到进阶,掌握容器化构建的核心工具
Dockerfile 是容器化开发中的关键工具。理解并掌握其使用方式,不仅能提高开发效率,还能让你的应用具备更强的可移植性和灵活性。通过优化配置和合理安排构建步骤,可以打造更轻量、更高效的容器镜像。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
消息中间件 NoSQL Kafka
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
374 4
|
缓存 开发者 Docker
Dockerfile是Docker容器化过程中的核心组件,它允许开发者以一种可重复、可移植的方式自动化地构建Docker镜像
【8月更文挑战第19天】Dockerfile是构建Docker镜像的脚本文件,含一系列指令定义镜像构建步骤。每条大写指令后跟至少一个参数,按序执行,每执行一条指令即生成新的镜像层。常用指令包括:FROM指定基础镜像;RUN执行构建命令;EXPOSE开放端口;CMD指定容器启动行为等。优化策略涉及减少镜像层数、选择轻量基础镜像、利用缓存及清理冗余文件。示例:基于Python应用的Dockerfile包括设置工作目录、复制文件、安装依赖等步骤。掌握Dockerfile有助于高效自动化构建镜像,加速应用部署。
179 1
|
安全 持续交付 Docker
深入探索Dockerfile:构建容器化应用的秘密武器
深入探索Dockerfile:构建容器化应用的秘密武器
157 2
|
7月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
2月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
|
3月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
218 1
Redis专题-实战篇二-商户查询缓存