docker--docker-Compose 安装与使用

简介: docker--docker-Compose 安装与使用

介绍


当我们部署一个 web 应用时,可能需要部署 nginx,redis,python,mysql 等一些容器,那么问题就来了,这么多容器我们维护起来也很麻烦,要从 dockerhub 拉取 image,要创建多个 container,要管理这些容器的启动删除停止。。。

这么麻烦的事,程序猿肯定是不愿意的,所以有人开发了 docker-compose,是基于 python 语言开发的。

docker compose 是一个工具,这个工具可以通过一个 yaml 文件定义多容器的 docker 应用,通过一条命令就可以 根据 yaml 文件的定义去创建或者管理多个容器。

docker-compose.yml 的三大部分:version,services,networks

  • version:docker compose 的版本,建议使用 3.x 就可以了
  • services:一个 services 代表一个 container,这个 container 可以从d ockerhub 的 image 来构建,或者从本地的 dockerfile build 出来的 images 来创建,services 的启动类似docker run,所以可以给 services 指定 network 和 volume 的引用
  • networks:使用的网络模式


安装


如果是 mac 或者 wins,安装了 docker 以后自带了 docker-compose,可以使用 docker-compose version 查看,但是如果是 linux 就不会安装 docker-compose,需要单独安装

docker-compose 是使用 python 语言安装的,所以我们需要安装好 python 和 pip

安装好 python 后,使用 pip 安装

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple docker-compose==1.24.1

查看 docker-compose 版本

docker-compose version


Docker-Compose 的快速上手


选一个目录存放 docker-compose 的配置文件,我在 root 下的 docker-compose

/root/docker-compose

在当前目录里编写一个 yml 文件,名字为 docker-compose.yml 内容如下

version: '3'
services:
  mynginx:
    image: nginx

使用 compose 操作容器(一定要进入配置文件目录)

后台启动容器,如果你的配置文件名不是 docker-compose.yml ,需要使用 -f 参数指定,例如 docker-compose up -d -f zouzou.yml , -f 参数的默认值是 docker-compose.yml

-d 是后台运行,不加 -d 参数是前台运行,ctrl+c 可以终止

docker-compose up -d

查看容器运行情况

docker-compose ps

停止并删除容器并删除 volume

docker-compose down --volumes

停止容器

docker-compose stop

停止并删除容器

docker-compose down

启动容器

docker-compose start

进入 mynginx 容器内部

docker-compose exec mynginx bash

注意:

  • 操作 docker-compose 一定要在配置文件 docker-compose.yml 文件路径下操作
  • 格式一定要注意,该空格要空格


docker-compose 的其他配置选项


docker-compose.yml 的三大部分:version,services,networks,最关键是 services 和 networks 两个部分

compose 设置网络模式

compose 使用端口映射

compose 设置文件共享

compose 管理多个容器

docker-compose.yml

version: '3'
services:
  nginx:
    image: nginx
    # 网络模式
    network_mode: "host"
    # 挂载
    volumes:
    - /home:/usr/local/nginx/html
    - /var/logs/nginx/logs:/usr/local/nginx/logs
    # 启动的命令
    command: /usr/local/nginx/sbin/nginx -g "daemon off;"
  redis:
    image: redis
    # 映射的端口,bridge模式
    ports:
    - "6380:6379"

相关文章
|
9月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
7月前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
1260 3
docker 安装 Postgres 17.6
|
6月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
760 6
|
6月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
602 2
|
12月前
|
存储 安全 C++
Odoo 安装方式选择:源码安装 vs Docker
Odoo部署常采用源码编译或Docker容器化,但分别面临依赖复杂、版本风险和服务化难题,以及镜像臃肿和扩展受限的问题。Websoft9提出混合方案,融合两者优势:通过智能环境适配、三阶段部署流程(环境预检、混合模式选择、持久化配置)及声明式YAML配置,实现高效、灵活的双模运行时。此方案显著降低依赖冲突解决时间(从83分钟至0),生产环境构建耗时缩短至8分钟,并达100% CVE漏洞修复率,适合ERP定制开发与规模化部署的企业需求。
|
10月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
1226 4
|
9月前
|
Linux Docker Windows
windows docker安装报错适用于 Linux 的 Windows 子系统必须更新到最新版本才能继续。可通过运行 “wsl.exe --update” 进行更新。
适用于 Linux 的 Windows 子系统需更新至最新版本(如 wsl.2.4.11.0.x64.msi)以解决 2025 年 Windows 更新后可能出现的兼容性问题。用户可通过运行 “wsl.exe --update” 或访问提供的链接下载升级包进行更新。
3735 0
|
10月前
|
Linux iOS开发 Docker
MyEMS开源系统安装之Linux/macOS上的DOcker
本指南详细介绍了如何在Linux/macOS上使用Docker部署MyEMS系统。主要内容包括:前置条件(如安装Docker、npm和MySQL),以及分步骤部署各个组件(如myems-api、myems-admin、myems-modbus-tcp等)。每个步骤涵盖源代码复制、环境配置、镜像构建、容器运行及日志管理等操作,并提供了多平台构建的支持。最后,指南还说明了默认端口和登录凭据,帮助用户快速启动并访问MyEMS的管理界面和Web界面。
376 1
下一篇
开通oss服务