Docker Compose V2 安装常用数据库MySQL+Mongo

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。

使用 Docker Compose V2 安装常用数据库 MySQL 和 MongoDB

Docker Compose 是一个用于定义和管理多容器 Docker 应用的工具。通过编写一个 docker-compose.yml 文件,可以轻松地配置和启动应用所需的所有服务。在本文中,我们将介绍如何使用 Docker Compose V2 安装和配置 MySQL 和 MongoDB 数据库。

一、安装 Docker 和 Docker Compose

在开始之前,请确保已经安装了 Docker 和 Docker Compose。可以使用以下命令进行安装:

1.1 安装 Docker

在 Ubuntu 系统上,可以使用以下命令安装 Docker:

sudo apt update
sudo apt install docker-ce docker-ce-cli containerd.io
​

1.2 安装 Docker Compose

在 Ubuntu 系统上,可以使用以下命令安装 Docker Compose:

sudo curl -L "https://github.com/docker/compose/releases/download/v2.5.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
​

检查安装是否成功:

docker-compose --version
​

二、编写 Docker Compose 配置文件

创建一个名为 docker-compose.yml 的文件,并添加以下内容:

version: '3.8'

services:
  mysql:
    image: mysql:8.0
    container_name: mysql_container
    environment:
      MYSQL_ROOT_PASSWORD: root_password
      MYSQL_DATABASE: example_db
      MYSQL_USER: user
      MYSQL_PASSWORD: user_password
    ports:
      - "3306:3306"
    volumes:
      - mysql_data:/var/lib/mysql

  mongo:
    image: mongo:5.0
    container_name: mongo_container
    ports:
      - "27017:27017"
    volumes:
      - mongo_data:/data/db

volumes:
  mysql_data:
  mongo_data:
​

2.1 配置说明

  • version: '3.8':指定 Docker Compose 文件的版本。

  • services:定义两个服务,mysqlmongo

  • mysql

    • image:指定使用 mysql:8.0 镜像。
    • container_name:容器名称为 mysql_container
    • environment:设置环境变量,包括 MySQL 的 root 密码、数据库名称、用户和用户密码。
    • ports:将容器的 3306 端口映射到主机的 3306 端口。
    • volumes:将主机的 mysql_data 卷挂载到容器的 /var/lib/mysql 目录。
  • mongo

    • image:指定使用 mongo:5.0 镜像。
    • container_name:容器名称为 mongo_container
    • ports:将容器的 27017 端口映射到主机的 27017 端口。
    • volumes:将主机的 mongo_data 卷挂载到容器的 /data/db 目录。
  • volumes:定义两个卷,mysql_datamongo_data,用于持久化数据。

三、启动和管理服务

3.1 启动服务

在包含 docker-compose.yml 文件的目录中运行以下命令,以启动 MySQL 和 MongoDB 服务:

docker-compose up -d
​
  • -d 参数表示以后台模式运行容器。

3.2 查看服务状态

使用以下命令查看服务的状态:

docker-compose ps
​

3.3 访问数据库

  • MySQL:可以通过连接 localhost:3306 访问 MySQL 数据库,使用 root 用户和密码 root_password 或者其他配置的用户和密码。
  • MongoDB:可以通过连接 localhost:27017 访问 MongoDB 数据库。

3.4 停止和删除服务

使用以下命令停止服务:

docker-compose down
​

使用以下命令停止并删除容器、网络和卷:

docker-compose down -v
​

四、总结

通过 Docker Compose V2,可以轻松地配置和管理 MySQL 和 MongoDB 数据库服务。只需编写一个简单的 docker-compose.yml 文件,并使用 Docker Compose 命令启动和管理服务,即可实现数据库的快速部署和高效管理。

思维导图

- 使用 Docker Compose 安装 MySQL 和 MongoDB
  - 安装 Docker 和 Docker Compose
    - 安装 Docker
    - 安装 Docker Compose
  - 编写 Docker Compose 配置文件
    - 定义 MySQL 服务
    - 定义 MongoDB 服务
  - 启动和管理服务
    - 启动服务
    - 查看服务状态
    - 访问数据库
    - 停止和删除服务
  - 总结
​

以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
6月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
480 158
|
6月前
|
人工智能 前端开发 Docker
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
在 AI 智能体开发中,开发者常面临本地调试与云端部署的矛盾。本文介绍如何通过 Docker Compose 与 Docker Offload 解决这一难题,实现从本地快速迭代到云端高效扩容的全流程。内容涵盖多服务协同、容器化配置、GPU 支持及实战案例,助你构建高效、一致的 AI 智能体开发环境。
612 2
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1142 152
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
878 156
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
709 8
|
6月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
6月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
6月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
6月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
6月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
481 156

热门文章

最新文章