前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用 compose 管理及编排容器

使用 compose 管理及编排容器

作者头像
山月
发布2020-06-18 15:42:49
4530
发布2020-06-18 15:42:49
举报
文章被收录于专栏:服务器运维笔记

当我们通过了解 docker 简易入门 本篇文章后,想必此时我们已经可以基于 nginx 镜像创建一个最简单的容器:启动一个最简单的 http 服务

代码语言:javascript
复制
$ docker run -d --name nginx -p 8888:80 nginx:alpine

$ docker ps -l
CONTAINER ID        IMAGE                COMMAND                  CREATED             STATUS              PORTS                    NAMES
404e88f0d90c        nginx:alpine         "nginx -g 'daemon of…"   4 minutes ago       Up 4 minutes        0.0.0.0:8888->80/tcp     nginx
CONTAINER ID        IMAGE                COMMAND                  CREATED             STATUS              PORTS                    NAMES

其中有诸多参数命令

  • -d: 启动一个 daemon 进程
  • --name: 为容器指定名称
  • -p host-port:container-port: 宿主机与容器端口映射,方便容器对外提供服务
  • nginx:alpine: 基于该镜像创建容器

这还只是一个简单的 nginx 的容器,如果有更多的容器那应该如何管理呢?

使用 docker-compose 来编排应用

快速开始

使用 docker-compose 创建一个最简单的容器,创建 docker-compose.yaml 文件。它使用配置文件的方式代替以前传参数的方式启动容器

代码语言:javascript
复制
version: '3'

services:
  nginx:
    image: nginx:alpine
    container_name: nginx-service
    restart: always
    ports:
      - "8888:80"

使用 docker-compose up 启动容器,它会自动查找当前目录下的 docker-compose.yaml 文件作为配置文件

代码语言:javascript
复制
# 启动
$ docker-compose up

# 查看日志
$ docker-compose logs

# 停止
$ docker-compose stop

# 删除
$ docker-compose rm

配置文件

关于 compose 的所有的配置请参考官方文档 compose file[1],大部分配置与 dockerfile 配置相类似

配置文件管理三种资源,servicesnetworks 以及 volumes,我们可以结合 docker-composetraefik 来管理应用。如以下配置文件将可以以域名 whiami.docker.localhost 来访问应用,详情可参考 traefik 简易入门

代码语言:javascript
复制
version: '3'

# 配置 service
services:
  whoami:
    image: containous/whoami
    restart: always
    labels:
      - "traefik.http.routers.whoami.rule=Host(`whoami.docker.localhost`)"

# 配置 network
networks:
  default:
    external:
      name: traefik_default

image

指定镜像

代码语言:javascript
复制
image: nginx

build

可以直接根据当前目录构建,而无需镜像

代码语言:javascript
复制
version: "3"
services:
  webapp:
    build: .

ports

主机与容器的端口映射,但是在 trafik 代理下往往不需要指定

代码语言:javascript
复制
ports:
  - "8080:80"

labels

用以筛选容器,在结合 traefik 或者 k8s 使用时,用以控制流量

代码语言:javascript
复制
labels:
  com.example.description: "Accounting webapp"
  com.example.department: "Finance"
  com.example.label-with-empty-value: ""

labels:
  - "com.example.description=Accounting webapp"
  - "com.example.department=Finance"
  - "com.example.label-with-empty-value"

container_name

指定容器名称,但是指定后不能够横向扩展,往往不会用到

容器管理

当使用 docker-compose 编排应用时,同时也可以选择 ctop 来管理容器。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-06-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈成长之路 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 快速开始
  • 配置文件
    • image
      • build
        • ports
          • labels
            • container_name
            • 容器管理
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档