Docker Compose常用命令与属性

news2024/11/28 19:27:48

在这里插入图片描述

大家好,今天给大家分享Docker Compose的常用命令,以及docker-compose文件的属性。Docker Compose 是一个用于定义和运行多容器 Docker 应用应用的重要工具。它通过一个配置文件(docker-compose.yml)来详细定义多个容器之间的关联、网络设置、服务端口等信息。使用一条简单的命令,就可以轻松启动、停止和管理这些容器,极大地简化了多容器应用的部署与管理流程,方便实现应用的快速构建、开发、测试以及部署。

Docker Compose 将所管理的容器划分为三层,即工程(project)、服务(service)和容器(container)。在 Docker Compose 运行目录下,所有文件(主要是 docker-compose.yml)共同构成一个工程。一个工程中包含多个服务,每个服务中又定义了容器运行所需的镜像、参数和依赖等。并且,一个服务可以包含多个容器实例。

关于 Docker 的安装和常用命令,本文不做详细说明,可以参考:
Docker在Windows与CentOS上的安装

Docker常用命令

一、Docker Compose常用命令

执行docker-compose命令时,需要在执行命令的目录下存在 docker-compose.yml 或者 docker-compose.yaml

ps:列出所有运行容器
docker-compose ps
build:构建或者重新构建服务
docker-compose build
logs:查看服务日志输出
docker-compose logs
port:打印绑定的公共端口
# 输出 mysql 服务 3306 端口所绑定的公共端口
docker-compose port mysql 3306
start:启动指定服务已存在的容器
docker-compose start mysql
stop:停止已运行的服务的容器
docker-compose stop mysql
rm:删除指定服务的容器
docker-compose rm mysql
scale:设置指定服务运气容器的个数,以 service=num 形式指定
docker-compose mysql user=3 movie=3
run:在一个服务上执行一个命令
docker-compose run web bash
up:构建、启动容器
docker-compose up
注意:
  • docker-compose的文件,只有在文件名为docker-compose时才可以使用docker-compose up命令,如果名字为自定义时,需要指定文件名才行,命令为:
docker-compose -f my-compose.yml up
  • docker-compose文件名后缀使用 .yml 或 .yaml都可。
  • 若是要后台运行,加上-d
docker-compose up -d
kill:通过发送 SIGKILL 信号来停止指定服务的容器
docker-compose kill mysql
pull:下载服务镜像
docker-compose pull mysql:lasted

二、docker-compose.yaml文件属性

Docker Compose 的 yaml 文件有着严格的缩进和空格要求,一般来说,它主要由以下几个部分构成:

首先是版本(Version),这是 Docker Compose 文件的顶级元素,用于明确所采用的 Docker Compose 文件版本,进而确定所使用的语法及支持的功能。

其次是服务(Services),该部分对应用程序的各个服务或容器进行定义。每个服务都拥有独特的名称,并囊括了该服务的配置信息,比如所应用的镜像、环境变量、端口映射、卷挂载等。

再者是网络(Networks),这部分负责定义应用程序的网络配置。可以创建自定义网络,并明确容器连接到哪个网络上,以实现容器之间的顺畅通信。

还有卷(Volumes),该部分定义了应用程序的卷挂载配置。可以指定容器与宿主机之间文件或目录的映射关系,从而实现数据的持久化和共享。

另外,环境变量(Environment Variables)也是重要部分,在服务的配置中,可以通过 environment 或 env_file 字段来指定环境变量,这些环境变量会被传递到容器内运行的应用程序中。

同时,端口映射(Port Mapping)也不可或缺,在服务的配置中,可以利用 ports 字段来明确容器端口与宿主机端口之间的映射关系,以此实现从宿主机访问容器内运行的服务。

最后是卷挂载(Volume Mounting),在服务的配置中,可以通过 volumes 字段来指定容器内路径与宿主机路径之间的映射关系,使容器与宿主机能够共享文件和数据。

官方文档:https://docs.docker.com/compose/reference/build/

Compose文与和Docker的兼容性:

目前 Compose 文件格式有3个版本,分别为1、2.x 和 3.x。
主流的为 3.x 其支持 docker 1.13.0 及其以上的版本。

version

'3’表示使用第三代语法来构建 docker-compose.yaml 文件。

services

用来表示 compose 需要启动的服务。

image

指定启动容器的镜像,可以是镜像仓库/标签或者镜像id(或者id的前一部分)

container_name

容器名称,指定一个自定义容器名,而不是默认生成的名称。

environment

此节点下的信息会当作环境变量传入容器。

ports

本地端口/容器端口,将容器中的端口映射到本地端口上。

restart

always 表示如果服务启动不成功会一直尝试。

volumes

映射容器中的文件到本地,本地的也会映射到容器中。

depends_on

可以配置依赖服务,表示需要先启动 depends_on 下面的服务后,再启动本服务。

build

用来构建指定路径的Dockerfile文件以及args参数

version: '2'
services:
  webapp:
    build:
      context: ./my_dir    #如果是.表示当前路径
      dockerfile: Dockerfile-alternate  # 指定Dockerfile文件名。如果上面context指定了文件名,这里就不用本属性了
      args:
        buildno: 1

webapp服务将会通过./my_dir目录下的Dockerfile-alternate文件构建容器镜像。
如果你同时指定image和build,则compose会通过build指定的目录构建容器镜像,而构建的镜像名为image中指定的镜像名和标签。
image: webapp:tag
这将由./dir构建的名为webapp和标记为tag的镜像。

image

image指定启动容器的镜像,可以是镜像仓库/标签或者镜像id(或者id的前一部分)

image: mysql
image: ubuntu:14.03
image: tutum/influxdb
image: example-registry.com:3000/postgresql
image: a4nhg65fd

如果镜像不存在,Compose将尝试从官方镜像仓库将其pull下来,如果你还指定了build,在这种情况下,它将使用指定的build选项构建它,并使用image指定的名字和标记对其进行标记。

volumes

卷挂载路径设置,就是将容器中的文件映射到宿主机中,方便修改。

volumes:
  # 只需指定一个路径,让引擎创建一个卷
  - /var/lib/mysql
 
  # 指定绝对路径映射
  - /opt/data:/var/lib/mysql
  
  # 指定相对路径映射
  - ./cache:/tmp/cache
  
  # 文件映射
  - ./cache/abc.java:/tmp/cache/abc.java
 
  # 用户主目录相对路径映射,此处 ro 下面详解
  - ~/configs:/etc/configs/:ro
 
  # 命名卷
  - datavolume:/var/lib/mysql
ro、rw详解:
  • 不指定
    文件:宿主机修改该文件后容器里面看不到变化;容器里面修改该文件,宿主机也看不到变化
    文件夹:不管是宿主机还是容器内修改、新增、删除文件,都会相互同步

  • ro
    文件:容器内不能修改,会提示read-only
    文件夹:容器内不能修改、新增、删除文件夹中的文件,会提示read-only

  • rw
    文件:不管是宿主机还是容器内修改,都会相互同步,但容器内不允许删除,会提示Device or resource busy;宿主机删除文件,容器内的不会被同步
    文件夹:不管是宿主机还是容器内修改、新增、删除文件,都会相互同步

links

链接到另一个服务中的容器。 请指定服务名称和链接别名(SERVICE:ALIAS),或者仅指定服务名称。

web:
  links:
   - db
   - db:database
   - redis

links也可以起到和depends_on相似的功能,即定义服务之间的依赖关系,从而确定服务启动的顺序。

external_links

链接到docker-compose.yml 外部的容器,甚至并非 Compose 管理的容器。参数格式跟 links 类似。

external_links:
 - redis_1
 - project_db_1:mysql
 - project_db_1:postgresql
restart

设置容器重启策略

# 默认策略,在任何情况下都不会重启容器
restart: "no"
# 容器总是在停止后重新启动
restart: always
# 容器非正常退出时,退出状态非0才会重启   
restart: on-failure
# 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器
restart: unless-stopped
network_mode

设置网络模式

# 桥接模式
network_mode: "bridge"
# 本机模式
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"
networks

配置容器连接的网络,引用顶级 networks 下的条目 。

services:
  some-service:
    networks:
      some-network:
        aliases:
         - alias1
      other-network:
        aliases:
         - alias2
networks:
  some-network:
    driver: custom-driver-1

注意:
aliases :同一网络上的其他容器可以使用服务名称或此别名来连接到对应容器的服务。

expose

暴露端口,但不映射到宿主机,只被连接的服务访问。 仅可以指定内部端口为参数。

expose:
 - "3000"
 - "8000"
ports

暴露端口信息。 常用的简单格式:使用宿主机:容器(HOST:CONTAINER)。

ports:
 - "3000"
 - "3000-3005"
 - "8000:8000"
 - "9090-9091:8080-8081"
 - "49100:22"
 - "127.0.0.1:8001:8001"
 - "127.0.0.1:5000-5010:5000-5010"
 - "6060:6060/udp"

在v3.2中ports的长格式的语法允许配置不能用短格式表示的附加字段。 长格式:

ports:
  - target: 80
    published: 8080
    protocol: tcp
    mode: host

target:容器内的端口
published:物理主机的端口
protocol:端口协议(tcp或udp)
mode:host 和ingress 两种模式,host用于在每个节点上发布主机端口,ingress 用于被负载平衡的swarm模式端口。

pid

将pid模式设置为主机pid模式。 这就打开了容器与主机操作系统之间的共享pid地址空间。 使用此标志启动的容器将能够访问和操作裸机的命名空间中的其他容器,反之亦然。即打开该选项的容器可以相互通过进程 ID 来访问和操作。

pid: "host"
container_name

指定一个自定义容器名称,而不是生成的默认名称。

version: '3'
services:
  node-exporter:
    image: prom/node-exporter:latest
    # 由于Docker容器名称必须是唯一的,因此如果指定了自定义名称,则无法将服务扩展到多个容器。
    container_name: node-exporter
    restart: always
    ports:
      - "9100:9100"
environment

配置环境变量

version: '3'
services:
  mysqld-exporter:
    image: prom/mysqld-exporter
    container_name: mysqld-exporter
    restart: always
    ports:
      - "9104:9104"
    environment:
      - DATA_SOURCE_NAME="user:password@(hostname:3306)/"

三、docker-compose.yaml文件示例

以下是一个完成的 docker-compose.yaml 文件内容示例:

version: "3"
services:
    redis:
        image: redis:latest
        ports:
            - "6379:6379"
        container_name: im-redis-compose
        restart: always
        command: redis-server --appendonly yes
    
    rabbitmq:
        image: rabbitmq:management
        ports:
            - "5672:5672"
            - "15672:15672"
        container_name: im-rabbitmq-compose
        environment:
            RABBITMQ_DEFAULT_USER: guest
            RABBITMQ_DEFAULT_PASS: guest
            RABBITMQ_DEFAULT_VHOST: my_vhost
 
    backend:
        build: .
        links:
            - redis
            - rabbitmq
        container_name: im-server-compose
        restart: on-failure
        depends_on:
            - rabbitmq
            - redis
        ports:
            - "3000:3000"
        command: sh -c './wait-for.sh rabbitmq:15672'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1659132.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

爬虫-无限debug场景 解决方式

解决无限debug 场景1 1. 鼠标右键 选择 continue to here(此处不停留)2. 鼠标右键 选择 edite breakpoint 设置 10 保证条件不成立 这行永远不执行3.方法置空 1. 方法调用加断点2. 控制台 setInterval function name() {}4. 替换文件 5. hoo…

如何使用phpMyAdmin删除数据库中的表?

本周有一个客户,购买Hostease的Linux虚拟主机,询问我们的在线客服,如何使用phpMyAdmin删除数据库中的表?我们为用户提供相关教程,用户很快解决了遇到的问题。在此,我们分享这个操作教程,希望可以…

LeetCode63:不同路径Ⅱ

题目描述 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。 现在考虑网格中有障碍物。那么从左上角…

飞凌嵌入式FET113i-S核心板在国产FTU中的适配性分析

智能电网建设的不断推进,使配电自动化成为了提升电网运行效率、保障供电质量的关键技术。在配电自动化系统中,馈线终端单元(FTU)作为连接电网与用户的重要节点,承担着实时监控、故障检测与隔离、远程控制等多项关键任务…

SpringMVC传递参数

1.RequestMapping RequestMapping本身可以处理,get或post,指定了get或post之后,就只能处理对应的请求。 RequestMapping(value{"haihiyo","goodMoring"},methodRequestMethod.POST)2.RestFul风格 RestFul是一种风格 比如:网站的访…

知识付费系统怎么搭建_轻松拥有知识付费平台

在信息爆炸的时代,知识的获取已不再局限于传统的课堂和书籍。随着科技的进步和互联网的普及,我们迎来了一个全新的知识获取方式——知识付费。今天,就让我们一起探讨如何搭建一个专属于您的知识付费系统,开启智慧的大门&#xff0…

VScode查看以十六进制查看文件的插件说明

找到插件并下载 打开指定的文件 选择打开方式即可 结果如下

AI写的论文AI疑似度太高怎么办?教你一招解决

随着 AI 技术迅猛发展,各种AI辅助论文写作的工具层出不穷! 为了防止有人利用AI工具进行论文代写,在最新的学位法中已经明确规定“已经获得学位者,在获得该学位过程中如有人工智能代写等学术不端行为,经学位评定委员会…

诊所医院超常规运营管理思维课程

本课程旨在引领医疗机构管理者超越传统思维,探索创新运营管理策略。学员将学习领先的医疗管理理念、创新的运营模式,以及如何应对挑战和变革。课程内容涵盖战略规划、资源优化、服务创新等,帮助管理者提升运营效率,提供更优质的医…

什么是MVC?什么是SpringMVC?什么是三层架构?

文章目录 应用分层什么是MVC?什么是 SpringMVC?三层架构三层架构和MVC的关系 应用分层 在讲解什么是MVC之前,先来理解一下什么是应用分层。 应用分层是一种软件开发设计思想,将应用程序划分成N个层次,每个层次都分别负责自己的…

一对一WebRTC视频通话系列(五)——综合调试和功能完善

本系列博客主要记录一对一WebRTC视频通话实现过程中的一些重点&#xff0c;代码全部进行了注释&#xff0c;便于理解WebRTC整体实现。 本专栏知识点是通过<零声教育>的音视频流媒体高级开发课程进行系统学习&#xff0c;梳理总结后写下文章&#xff0c;对音视频相关内容感…

燃料电池发电系统详解

目录 前言 组成结构 系统参数 常见问题 参考资料 前言 见《氢燃料电池技术综述》 见《燃料电池工作原理详解》 组成结构 燃料电池发电系统&#xff0c;由多个子系统和子模块组成&#xff0c;示例如下&#xff1a; 燃料处理系统&#xff08;fuel processing system&#xf…

开启短剧新纪元,短剧小程序开发等你来探索

一、引言 在信息爆炸的时代&#xff0c;短视频已经成为人们日常生活中不可或缺的一部分。然而&#xff0c;随着人们对内容品质要求的不断提高&#xff0c;短剧作为一种新兴的内容形式&#xff0c;正逐渐崭露头角。为了满足广大用户对短剧内容的需求&#xff0c;我们倾力打造了…

Dark Reader:夜间模式,启动!

名人说&#xff1a;一点浩然气&#xff0c;千里快哉风。 ——苏轼 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 一、介绍二、下载安装1、Chrome应用商店&#xff08;需科学&#xff09;2、第三方直链下载 三、使…

在代码开发中的O(VO,BO,PO,DO,DTO)介绍

先来看个图各种O的地位&#xff1a; 从图中可以看到各种O 的位置和用法&#xff0c;接下来&#xff0c;进行简单对O进行介绍&#xff1a; BO&#xff1a;Business Object 业务对象&#xff0c;PO是一条交易记录&#xff0c;BO是一个人全部的交易记录集合对象 DTO&#xff1a;…

NSSCTF | [SWPUCTF 2021 新生赛]easy_sql

打开题目&#xff0c;提示输入一些东西&#xff0c;很显眼的可以看到网站标题为“参数是wllm” 首先单引号判断闭合方式 ?wllm1 报错了&#xff0c;可以判断为单引号闭合。 然后判断字节数&#xff08;注意‘--’后面的空格&#xff09; ?wllm1 order by 3-- 接着输入4就…

MQTT客户端软件MQTT.fx

mqtt.fx支持通过 Topic 订阅和发布消息&#xff0c;用来前期和物联网云平台调试非常方便。 在云端创建产品后&#xff0c;一般先测试一下对接接口是否可以正常使用&#xff01;该工具目前可以对接百度云、华为云&#xff0c;以及自己使用EMQ-X搭建的Mqtt服务器。 下载安装 链…

[蓝桥杯]真题讲解:抓娃娃(思维+二分)

[蓝桥杯]真题讲解&#xff1a;抓娃娃&#xff08;思维二分&#xff09; 一、视频讲解二、正解代码1、C2、python33、Java 一、视频讲解 [蓝桥杯]真题讲解&#xff1a;抓娃娃&#xff08;思维二分&#xff09;&#xff09; 二、正解代码 1、C #include<bits/stdc.h> #d…

SpringBoot 具体是做什么的?

Spring Boot是一个用于构建独立的、生产级别的、基于Spring框架的应用程序的开源框架。它的目标是简化Spring应用程序的开发和部署过程&#xff0c;通过提供一种快速、便捷的方式来创建Spring应用程序&#xff0c;同时保持Spring的灵活性和强大特性。 1. 简化Spring应用程序开…

【算法刨析】完全背包

完全背包与01背包的区别 01背包对于一个物品只能选择一次&#xff0c;但是完全背包可以选择任意次&#xff1b; 思路 和01背包类似&#xff0c;01背包我们只需要判断选或不选&#xff0c;完全背包也是如此&#xff0c;不同的是&#xff0c;对于这个物品我们在判断选后在增加一…