百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Docker Compose 命令大全,Linux 运维工程师收藏!

wptr33 2024-12-19 16:51 19 浏览

Docker Compose是一个用于定义和运行多容器Docker应用程序的工具。通过一个YAML文件来配置你的应用服务,然后使用一个简单的命令,就可以创建并启动所有服务。在这篇文章中,我们将详细介绍Docker Compose的命令和用法。

Docker Compose 基础概念

Docker Compose 是 Docker 提供的一个工具,用于定义和管理多容器的 Docker 应用程序。通过 Docker Compose,用户可以使用简单的 YAML 文件 (docker-compose.yml) 来定义应用程序的各项服务、网络和卷等配置。然后通过简单的命令来启动、停止和管理这些服务。

Compose 主要解决了以下问题:

  • 多容器管理:可以通过一个命令同时管理多个容器。
  • 跨平台部署:开发环境与生产环境可以共享相同的 Compose 配置,确保环境一致性。
  • 依赖服务的管理:通过 Compose,可以定义服务之间的依赖关系。

在使用 Docker Compose 之前,我们需要先定义 docker-compose.yml 文件,该文件的基本结构如下:

version: '3'
services:
  web:
    image: nginx:alpine
    ports:
      - "8080:80"
  db:
    image: postgres:latest
    environment:
      POSTGRES_USER: example
      POSTGRES_PASSWORD: example
volumes:
  db_data:
networks:
  app_net:

这个文件定义了两个服务:webdbweb 使用 Nginx 镜像,并映射主机的 8080 端口到容器的 80 端口;db 使用 Postgres 数据库,并设置了环境变量。volumesnetworks 部分则分别定义了数据卷和网络配置。

Docker Compose 命令详解

docker-compose up

docker-compose up 命令用于构建、启动并运行所有在 docker-compose.yml 文件中定义的服务。该命令会启动所有容器,并根据需要构建镜像。

docker-compose up
  • -d(后台运行):此选项会在后台运行所有服务。
docker-compose up -d

输出示例:

Creating network "myapp_default" with the default driver
Creating volume "myapp_db_data" with default driver
Creating myapp_db_1 ... done
Creating myapp_web_1 ... done
  • --build:强制重建服务镜像。
docker-compose up --build
  • --scale:设置指定服务的副本数量。
docker-compose up --scale web=3
  1. 创建网络:Compose 会为服务创建自定义网络,以便服务之间可以相互通信。
  2. 创建卷:如果 docker-compose.yml 中定义了卷,Compose 会自动创建这些卷。
  3. 启动服务:根据 docker-compose.yml 中的配置,Compose 会拉取镜像(如果镜像不存在),并创建容器。

docker-compose down

docker-compose down 用于停止并删除通过 docker-compose up 启动的容器、网络、卷和镜像。它的作用相当于 docker-compose stop 加上 docker-compose rm

docker-compose down
  • -v:删除与服务相关联的卷。
docker-compose down -v
  • --rmi all:删除与服务相关联的镜像。
docker-compose down --rmi all
  • --remove-orphans:删除没有在 docker-compose.yml 文件中定义的容器。
docker-compose down --remove-orphans
  1. docker-compose down 会删除所有服务的容器以及网络,但默认不会删除数据卷,除非使用 -v 选项。
  2. 这个命令适用于完全关闭应用程序,并且确保所有相关资源都被清理干净。

docker-compose start 和 docker-compose stop

  • docker-compose start:用于启动已经停止的服务,但不会创建新容器。
  • docker-compose stop:用于停止正在运行的服务,但不会删除容器。
docker-compose stop
docker-compose start
  • docker-compose start 适用于当服务已经存在且容器已被停止时,重新启动它们。
  • docker-compose stop 则用于暂时停止服务,而不需要删除容器。

docker-compose restart

docker-compose restart 用于重启正在运行的服务。

docker-compose restart
  • 指定服务:可以重启某个特定的服务。
docker-compose restart web

当配置文件发生更改,或服务需要重新启动以应用某些更改时,restart 命令非常有用。

其他重要命令

docker-compose build

docker-compose build 命令用于手动构建服务的 Docker 镜像。通常在镜像发生更改时使用,例如更新了 Dockerfile。

docker-compose build
  • --no-cache:在构建过程中不使用缓存。
docker-compose build --no-cache
  • --pull:强制拉取最新的镜像。
docker-compose build --pull
  • 如果在服务的 Dockerfile 中进行了更改,可以通过此命令手动重建镜像,而无需先启动服务。

docker-compose exec

docker-compose exec 命令用于在指定的服务容器中执行命令。

docker-compose exec web bash
  • 当需要进入容器内部进行调试或执行某些命令时,此命令非常有用。例如,进入 web 容器后,可以执行诸如查看日志文件、检查网络连接等操作。

docker-compose logs

docker-compose logs 命令用于查看服务的日志输出。日志可以帮助诊断服务的运行情况,特别是在服务启动失败或出现错误时。

docker-compose logs
  • -f:实时跟踪日志输出(相当于 tail -f)。
docker-compose logs -f
  • 指定服务:查看特定服务的日志。
docker-compose logs web
  • 当应用程序出错或需要查看某些服务的运行状态时,可以通过 docker-compose logs 查看详细的日志信息。

docker-compose ps

docker-compose ps 命令用于列出当前运行的容器及其状态。与 Docker 的 docker ps 命令类似,但它只列出与 docker-compose.yml 文件相关的容器。

docker-compose ps
      Name                Command            State           Ports         
------------------------------------------------------------------------
myapp_web_1     "nginx -g 'daemon of…"   Up      0.0.0.0:8080->80/tcp    
myapp_db_1      "docker-entrypoint.s…"   Up      5432/tcp  
  • 当需要查看哪些服务正在运行,以及它们的端口映射时,可以使用此命令。

docker-compose run

docker-compose run 命令用于启动一个一次性的容器,并执行指定的命令。该容器在执行完命令后会自动删除。

docker-compose run web bash
  • --rm:执行完后自动删除容器。
docker-compose run --rm web python manage.py migrate
  • 该命令适用于执行临时任务,例如数据库迁移或调试。

相关推荐

MYSQL术语介绍:dynamic row format

InnoDB行格式。因为可变长度列值存储在保存行数据的页面之外,所以对于包含大对象的行非常有效。由于通常不会访问大字段来评估查询条件,因此不会经常将它们带入缓冲池,从而减少I/O操作并更好地利用缓...

阿里面试:MySQL Binlog有哪些格式?底层原理?优缺点?

binlog的格式也有三种:STATEMENT、ROW、MIXED,下面我详解binlog三种模式@mikechenStatement模式Statement模式:是基于SQL语句的复制(statem...

Mysql日期格式化显示“年月”(mysql日期格式化)

数据库中存储格式为DATE,如果只显示年月,就需要将日期数据格式化。下面通过两种方式对其格式化显示:...

看完这篇还不懂 MySQL 主从复制,可以回家躺平了

我们在平时工作中,使用最多的数据库就是MySQL...

MySQL binlog format (Statement、Row、Mixed) 二进制日志格式

MySQL的binlog日志作用是用来记录MySQL内部增删改查等对MySQL数据库有更新的内容的记录(对数据库的改动),对数据库的查询select或show等不会被binlog日志记录,主要用于数据...

性能优化-界面卡顿和丢帧(Choreographer 代码检测)

标签:ChoreographerUI卡顿UI丢帧本文将介绍3个知识点:获取系统UI刷新频率检测UI丢帧和卡顿输出UI丢帧和卡顿堆栈信息...

使用Java分析器优化代码性能,解决OOM问题

背景最近我一直在做性能优化,对一个单机应用做性能优化。主要是涉及到解析和导入导出相关的业务。大致说一下这个单机应用干嘛的:制作票样,类似于答题卡。发给某些人填写,然后通过单机python图像识别存到数...

面试必问的HashCode技术内幕(hashmap面试题原理)

3hashCode的内幕tips:面试常问/常用/常出错...

实战Netty!基于私有协议,怎样快速开发网络通信服务

私有协议编写目的本文档用于描述边缘计算单元(以下简称边缘盒)与上位机配置软件(以下简称上位机)之间进行的数据交互通信协议。通信方式...

C#工控上位机系列(2)- 串口通信/监控工具

工控机通常都带有很多串口(10个),而且可以通过Moxa卡扩展串口.但Moxa的串口和电脑自带的串口还是有点区别C#里面没区别,但之前VB6的MSComm控件有时就会有不一样的地方.支持串口通讯...

Java加密与解密之消息摘要算法1(消息摘要(hash函数编码法),又称数字指纹 ( ))

消息摘要算法有3大类,分别是:MD、SHA、MAC,通常用于数据完整性的验证。MD:MessageDigest消息摘要算法。包括:MD2,MD4,MD53种算法。SHA:SecureHashA...

zookeeper的Leader选举源码解析(zookeeper角色选举角色包括)

作者:京东物流梁吉超zookeeper是一个分布式服务框架,主要解决分布式应用中常见的多种数据问题,例如集群管理,状态同步等。为解决这些问题zookeeper需要Leader选举进行保障数据的强一致...

Java 中五种最常见加密算法:原理、应用与代码实现

引言在现代软件开发中,数据安全至关重要。无论是用户密码存储、敏感信息传输,还是系统间的通信,加密技术都扮演着核心角色。Java作为广泛使用的编程语言,通过javax.crypto和java.s...

干货|6招学会调用NFC的各个功能(调出nfc)

现在越来越多的手机支持NFC功能,这种轻松、安全、迅速的通信的无线连接技术,能够让我们的手机替代门禁卡、公交卡、银行卡甚至是车钥匙,那么怎么让APP中能够调用这个功能呢?今天小编就来教给大家!...

一文读懂流媒体协议之RTP 协议(rtp流媒体服务器)

一、简介1.1RTPRTP全名是Real-timeTransportProtocol(实时传输协议)。它是IETF提出的一个标准,对应的RFC文档为RFC3550(RFC1889为其过期版本)。...