Docker Compose 安装与使用(常用指令)

简介: Docker Compose 安装与使用(常用指令)

一、简介

  • Docker Compose 是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建、启动和停止。使用步骤:
1. 利用 Dockerfile 定义运行环境镜像
2. 使用 docker-compose.yml 家义组成应用的各服务
3. 运行 docker-compose up 启动应用

二、安装与使用

  • 除了在 Linux 上安装 docker 时,不会自动安装 docker-compose,其他平台(windowmac)都会自动安装好 docker-compose
  • 安装好 docker 后,可以通过下面命令检查是否顺带安装好了 docker-compose,没有安装好,可以按 官网的方式进行安装,然后检查是否安装成功。
$ docker-compose -v
  • 创建一个工作目录
$ mkdir ~/docker-compose
$ cd ~/docker-compose
  • 编写 docker-compose.yml 文件,文件名固定写法。在 yml 语法中 - 表示数组写法,可以多个。
// 版本
version: '1'
// 服务
services:
    // 服务名称(也就是容器名称)
    nginx:
        // 镜像
        image: nginx:2.0
        ports:
            // 端口映射
            - 80:80
        // 关联的容器(也就是可以访问的容器)
        links:
            // 关联容器名称
            - app
        // 目录映射
        volumes:
            - ./nginx/conf.d:/etc/nginx/conf.d
            -  ....可以多个
    // 服务名称(也就是容器名称)
    app:
        image: app
        // 对外暴露的端口
        expose:
            - "8080"
  • 创建 ./nginx/conf.d 目录,然后建一个 nginx 配置文件
# 创建配置文件夹
$ mkdir -p ./nginx/conf.d
# 进入配置文件夹
$ cd ./nginx/conf.d
# 新建 nginx 配置文件,名字无所谓,主要是后缀
$ vim mynginx.conf
  • mynginx.conf 内容
server {
    listen: 80;
    access_log off;
    location / {
        # app 位置就是 links 里面存在容器名称加上容器暴露的端口
        proxy_pass http://app:8080
    }
}
  • 然后回到 ~/docker-compose 目录启动容器,启动后通过 http://IP地址 访问
$ cd ~/docker-compose
# 启动容器
$ docker-compose up

三、常用指令

  • 启动和停止服务
# 启动项目中的服务
$ docker-compose up
# 启动项目中的服务并设置组名称(默认使用当前文件夹名称,单个容器使用的是 --name 设置名称)
# 组名称也就是项目名称 -p;--project xxx
$ docker-compose -p myproject up
# 启动服务并在后台运行
$ docker-compose up -d
# 停止服务
$ docker-compose stop
  • 构建和重构服务
# 构建服务的镜像
$ docker-compose build
# 如果服务镜像不存在,则构建镜像并启动服务
$ docker-compose up –build
# 重构服务
$ docker-compose up –force-recreate
  • 查看服务信息
# 查看项目中所有服务的信息
$ docker-compose ps
# 查看容器的日志
$ docker-compose logs
# 在服务镜像的容器中执行命令
$ docker-compose exec service_name command
  • 删除服务
# 停止所有容器后,删除所有服务容器
$ docker-compose down
# 停止所有容器后,删除所有服务容器与对应的数据卷
$ docker-compose down -v 
# 删除所有停止后的服务容器
$ docker-compose rm --stop
相关文章
|
5天前
|
Docker Python 容器
python检测docker compose文件是否正确
python检测docker compose文件是否正确
|
6天前
|
Docker 容器
Docker安装及镜像源修改
本文介绍了Docker的安装过程和如何修改Docker镜像源以加速下载。包括更新系统包、安装所需软件包、设置yum源、安装Docker以及验证安装是否成功。接着,提供了修改Docker镜像源的步骤,包括创建配置文件、编辑配置文件以设置镜像加速地址,并提供了几个常用的国内镜像源地址。最后,通过重启Docker服务和检查配置是否生效来完成镜像源的修改。
Docker安装及镜像源修改
|
7天前
|
Docker 容器
centos7.3之安装docker
centos7.3之安装docker
|
1月前
|
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
|
20天前
|
运维 Docker 微服务
掌握 Docker Compose:简化你的多容器应用部署
在微服务架构和容器化技术普及的今天,管理多容器部署变得颇具挑战。Docker Compose 通过一个 YAML 文件定义和运行多容器应用,简化了部署和运维。本文介绍其基本概念、使用方法及优势,包括服务、项目、卷和网络等核心概念,并提供从安装到管理服务的详细步骤,助你轻松掌握 Docker Compose,提高开发效率和应用运维质量。
|
17天前
|
Prometheus 监控 Cloud Native
docker安装prometheus+Granfan并监控容器
【9月更文挑战第14天】本文介绍了在Docker中安装Prometheus与Grafana并监控容器的步骤,包括创建配置文件、运行Prometheus与Grafana容器,以及在Grafana中配置数据源和创建监控仪表盘,展示了如何通过Prometheus抓取数据并利用Grafana展示容器的CPU使用率等关键指标。
|
6天前
|
Docker 容器
7-7|salt检测docker compose文件是否正常
7-7|salt检测docker compose文件是否正常
|
6天前
|
运维 监控 Docker
掌握 Docker Compose:简化你的多容器应用部署
在微服务架构和容器化技术日益普及的今天,管理多个容器的部署和运维变得颇具挑战。Docker Compose 通过一个 YAML 文件定义和运行多容器 Docker 应用,极大地简化了这一过程。本文介绍了 Docker Compose 的基本概念、使用方法及其优势,包括简化配置、一键部署、易于版本控制和环境一致性。通过具体示例展示了如何安装 Docker Compose、创建 `docker-compose.yml` 文件并管理服务。掌握 Docker Compose 可显著提高开发效率和应用运维质量。
|
14天前
|
负载均衡 网络协议 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基本概念和类型,包括桥接网络、宿主网络、覆盖网络和 Macvlan 网络等,并提供了创建、管理和配置自定义网络的实用命令。通过掌握这些知识,开发者可以构建更健壮和灵活的容器化应用,提高应用的可扩展性和安全性。
|
12天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
192 69
下一篇
无影云桌面