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

本文涉及的产品
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 
目录
相关文章
|
4月前
|
Ubuntu 关系型数据库 MySQL
MySQL源码编译安装
本文详细介绍了MySQL 8.0及8.4版本的源码编译安装全过程,涵盖用户创建、依赖安装、cmake配置、编译优化等步骤,并提供支持多Linux发行版的一键安装脚本,适用于定制化数据库部署需求。
677 4
MySQL源码编译安装
|
4月前
|
Ubuntu 关系型数据库 MySQL
MySQL二进制包安装
本文详细介绍了在多种Linux系统上通过二进制包安装MySQL 8.0和8.4版本的完整过程,涵盖用户创建、glibc版本匹配、程序解压、环境变量配置、初始化数据库及服务启动等步骤,并提供支持多发行版的一键安装脚本,助力高效部署MySQL环境。
569 4
MySQL二进制包安装
|
4月前
|
安全 关系型数据库 MySQL
MySQL包安装 -- SUSE系列(离线RPM包安装MySQL)
本文详细介绍在openSUSE系统上通过离线RPM包安装MySQL 8.0和8.4版本的完整步骤,包括下载地址、RPM包解压、GPG密钥导入、使用rpm或zypper命令安装及服务启动验证,涵盖初始密码获取与安全修改方法,适用于无网络环境下的MySQL部署。
512 3
MySQL包安装 -- SUSE系列(离线RPM包安装MySQL)
|
4月前
|
关系型数据库 MySQL Linux
MySQL包安装 -- SUSE系列(SUSE资源库安装MySQL)
本文介绍了在openSUSE系统上通过SUSE资源库安装MySQL 8.0和8.4版本的完整步骤,包括配置国内镜像源、安装MySQL服务、启动并验证运行状态,以及修改初始密码等操作,适用于希望在SUSE系列系统中快速部署MySQL的用户。
369 3
MySQL包安装 -- SUSE系列(SUSE资源库安装MySQL)
|
4月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
617 5
|
4月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
439 2
|
4月前
|
Ubuntu 关系型数据库 MySQL
MySQL包安装 -- Debian系列(离线DEB包安装MySQL)
本文详细介绍了在Ubuntu 24.04、22.04、20.04及Debian 12系统上,通过离线DEB包安装MySQL 8.0和8.4版本的完整步骤。涵盖下载地址、依赖处理、dpkg安装顺序、配置方法及服务启动验证,确保用户可顺利部署MySQL数据库。
1737 0
MySQL包安装 -- Debian系列(离线DEB包安装MySQL)
|
4月前
|
运维 Ubuntu 关系型数据库
MySQL包安装 -- Debian系列(Apt资源库安装MySQL)
本文介绍了在Debian系列系统(如Ubuntu、Debian 11/12)中通过APT仓库安装MySQL 8.0和8.4版本的完整步骤,涵盖添加官方源、配置国内镜像、安装服务及初始化设置,并验证运行状态,适用于各类Linux运维场景。
1450 0
MySQL包安装 -- Debian系列(Apt资源库安装MySQL)
|
4月前
|
Oracle 关系型数据库 MySQL
MySQL包安装 -- RHEL系列(离线RPM包安装MySQL)
本文详细介绍在Rocky、CentOS、AlmaLinux、openEuler等主流Linux系统上,通过离线RPM包安装MySQL 8.0和8.4版本的完整步骤,涵盖下载、依赖处理、rpm/yum安装、服务启动、密码设置等关键环节,适用于多种企业级环境部署需求。
1163 0
MySQL包安装 -- RHEL系列(离线RPM包安装MySQL)