前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker Compose 官方阅读笔记

Docker Compose 官方阅读笔记

作者头像
java干货
发布2021-02-19 12:37:23
7880
发布2021-02-19 12:37:23
举报
文章被收录于专栏:java干货

我们将构建一个运行在Docker上的简单的Python Web应用程序。 应用程序使用Flask 框架,并在redis中维护一个计数器。 虽然示例使用python,即使你不熟悉它也没关系。

前言

确保你已经安装了docker enginedocker compose。不需要安装pythonredis,因为两者都是由docker镜像提供的。

如下:

第一步:设置

定义应用程序依赖关系

为该项目创建目录

在项目目录下创建一个名为app.py的文件,并设置内容如下:

在项目目录中创建另一个名为requirements.txt的文件,并设置内容如下:

第二步:创建Dockerfile文件

在这一步中,我们将编写一个构建docker镜像的dockerfile文件。该文件包含python应用程序所需的所有依赖项,也包括python本身。

在我们的项目目录中,创建一个名为dockerfile的文件并粘贴以下内容:

代码语言:javascript
复制
FROM python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]

命令的解释如下:

  • Python 3.4镜像基础上创建容器
  • 把当前目录添加到容器的/code目录中
  • 将容器的工作目录设置为/code
  • 安装python所需要的依赖
  • 设置容器的默认命令python app.py

第三步:在docker-compose.yml中定义服务

在我们的项目目录下创建一个名为docker-compose.yml的文件并粘贴下面的代码:

代码语言:javascript
复制
version: '3'
services:
  web:
    build: .
    ports:
     - "5000:5000"
    links:
     - redis
  redis:
    image: "redis:alpine"

这个组合文件定义了两个服务,webredisweb服务:

  • 使用从当前目录中的dockerfile构建的容器
  • 将容器上的暴露端口5000转发到主机上的端口5000。我们使用Flask web服务器的默认端口5000。

redis服务使用从docker注册表中心中提取的公共redis映像.

目录结构如下:

第四步:构建和运行我们的应用程序

  1. 从我们的项目目录中,通过运行docker-compose up启动您的应用程序.如下:

docker-compose.yml文件拉去Redis镜像,构建我们的镜像并启动服务。

  1. 在浏览器中输入http://localhost:5000/,浏览器回输出以下消息
代码语言:javascript
复制
Hello World! I have been seen 1 times.
  1. 刷新页面数字会递增
代码语言:javascript
复制
Hello World! I have been seen 2 times.
  1. 开启另一个终端使用 docker images 列出镜像。
  1. 停止应用程序,通过在第二个终端的项目目录中运行docker-compose down,或者在启动应用程序的原始终端中按ctrl + c

第五步:修改docker-cmopose.yml 添加挂载目录 如下:

代码语言:javascript
复制
version: '3'
services:
  web:
    build: .
    ports:
     - "5000:5000"
    volumes:
     - .:/code
  redis:
    image: "redis:alpine"

volumes 关键字挂在当前目录到容器的/code,允许我们即时修改代码,而无需重新生成镜像。

第六步:重新构建并运行应用程序

从项目目录中输入docker-compose up,然后用已更新的文件构建应用程序,运行它

代码语言:javascript
复制
$ docker-compose up
Creating network "composetest_default" with the default driver
Creating composetest_web_1 ...
Creating composetest_redis_1 ...
Creating composetest_web_1
Creating composetest_redis_1 ... done
Attaching to composetest_web_1, composetest_redis_1
web_1    |  * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
...

再次在Web浏览器中查看hello world消息,然后刷新以查看有没有递增。

第七步:更新应用程序

由于应用程序代码现在使用数据卷挂载到容器中,因此可以更改本地代码并立即查看更改后效果,而无需重新生成镜像。

  1. 更改app.py Hello World!Hello from Docker!:
代码语言:javascript
复制
return 'Hello from Docker! I have been seen {} times.\n'.format(count)
  1. 刷新浏览器,Hello World!更新成Hello from Docker 数字依旧递增

第八步:扩展其它命令

如果你想在后台运行你的服务,可以使用 -d 参数,并且可以使用docker-compose ps查看当前运行的服务。

代码语言:javascript
复制
$ docker-compose up -d
Starting composetest_redis_1...
Starting composetest_web_1...

$ docker-compose ps
Name                 Command            State       Ports
-------------------------------------------------------------------
composetest_redis_1   /usr/local/bin/run         Up
composetest_web_1     /bin/sh -c python app.py   Up      5000->5000/tcp

docker-compose run命令允许为服务运行一次性命令。例如,查看哪些环境变量可用于Web服务

代码语言:javascript
复制
 docker-compose run web env

可以参阅docker-compose --help以查看其他可用的命令。

如果开始使用docker-compose up -d运行服务,则可以使用 docker-compose stop 命令停止服务运行。

代码语言:javascript
复制
$ docker-compose stop

你可以把所有服务停下,用down命令完全移除容器。通过--volumes还删除redis容器使用的数据卷:

代码语言:javascript
复制
$ docker-compose down --volumes

翻译链接:https://docs.docker.com/compose/gettingstarted/#step-8-experiment-with-some-other-commands

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 第一步:设置
  • 第二步:创建Dockerfile文件
  • 第三步:在docker-compose.yml中定义服务
  • 第四步:构建和运行我们的应用程序
  • 第五步:修改docker-cmopose.yml 添加挂载目录 如下:
  • 第六步:重新构建并运行应用程序
  • 第七步:更新应用程序
  • 第八步:扩展其它命令
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档