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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
简介: 【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://www.aliyun.com/product/rds/mysql 
相关文章
|
4月前
|
存储 Java Linux
【Docker】(2)还在浏览网页寻找Docker命令?本文全面列举与使用Docker里的各个命令!想要什么命令直接从本文拿!
docker有着比VM更少的抽象层 由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用的都是实际物理机的硬件资源 因此在CPU、内存利用率上Docker将会在效率上有明显优势 docker利用的时宿主机的内核,而不需要加载操作系统OS内核 当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统内核 进而避免引寻、加载操作系统内核返回等比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载OS,返回新建过程时分钟级别的。 而Docker由于直接利用宿主机的操作系统,则省略了返回过程,因此新建一个Docker容器只需
482 124
|
4月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
636 5
|
7月前
|
安全 Unix Linux
Docker中授权普通用户使用docker命令以及解决无权限访问/var/run/docker.sock错误。
通过上述步骤,可以有效解决普通用户无法使用Docker命令的问题,同时处理 `/var/run/docker.sock`权限错误。这样的设置不仅方便用户使用Docker提供的各项服务,同时还能保护系统的安全性。在进行此类配置更改时,请确保理解每一步骤的作用及潜在的安全风险,尤其是在修改文件权限时。在实际的操作中,始终应该努力保持系统的最低必要权限,避免过度放宽权限,这是保障系统安全的一个重要方针。
2293 75
|
8月前
|
Docker 容器
Docker run命令-p参数详解
本文介绍Docker端口映射的基础用法。通过`docker run -p <宿主机端口>:<容器端口>`实现端口映射,例如`-p 5000:80`将宿主机5000端口映射到容器80端口,外部访问宿主机5000端口时流量会转发至容器内部的80端口。示例命令中,`-d`用于后台运行,`--restart=always`确保容器自动重启,`--name`指定容器名称。部署完成后可通过`http://服务器IP地址:5000`验证服务是否正常运行。
1119 57
|
8月前
|
存储 安全 数据建模
Docker数据卷深入解析与操作技巧
通过巧妙使用Docker数据卷,我们就能实现数据的灵活管理和无缝迁移,享受容器化的便捷,同时确保数据的安全与高效共享。
165 6
|
7月前
|
Docker 容器
熟悉Docker容器管理命令:start、stop与restart详细使用指南
掌握这些Docker容器管理命令对于维护应用程序的正常运行至关重要。在实际操作中,应注意容器配置、关联资源以及日志等信息,确保各项操作都能够顺畅并且安全地执行。
1230 0

热门文章

最新文章