docker镜像的理解和容器数据卷

简介: 这篇文章只要介绍对镜像的基本理解和使用,以及非常重要的容器数据卷

Docker镜像

镜像是什么

镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时库、环境变量和配置文件。

Docker镜像加载原理

UnionFS (联合文件系统)

bootfs:

rootfs

分层理解

特点

Docker的镜像都是只读的,当容器启动的时候,一个新的可写层被加载到镜像的顶部!

这一层就是我们通常多说的容器层,容器之下的都叫镜像层!

commit镜像

docker commit 提交容器成为一个新的副本

#命令和git原理类似
docker commit -m=“提交的描述信息”  -a=“作者” 容器id  目标镜像名:[tag]

实战测试

#1、启动一个默认的tomcat

#2、发现这个默认的tomcat,没有webapps应用,镜像的原因

#3、自己拷贝进去了基本的文件

#4、将我们操作过的容器通过commit提交为一个镜像,我们以后就使用我们修改过的镜像即可,这就是我们自己的镜像。
docker commit -a=“kuangshen” -m=“add webapps app”   容器id  镜像名:版本

容器数据卷

什么是容器数据卷

容器之间可以有一个数据共享的技术! docker容器中产生的数据可以 同步到本地

这就是卷技术 目录的挂载,将我们容器内的目录,挂载到Linux上面
image.png

容器的持久化和同步操作!容器间也可以数据共享

使用容器数据卷

方式一:直接使用命令来挂载 -v

dockerrun -it -v 主机目录:容器内目录

#测试
ji@ji-VirtualBox:~$ docker run -it -v /home/ji/ceshi:/* centos /bin/bash

image.png

保持文件的同步,可以保持双向的同步以后修改只需要在本地修改即可,容器内会自动同步

具名和匿名挂载

#匿名挂载
-v  容器内路径!
docker run -d -P --name nginx01 -v /etc/nginx nginx
-P   表示随机映射端口

#查看所有的volume的情况
docker volume ls

#这种就是匿名挂载,我们在-v 只写了容器内的路径,没有写容器外的路径

#具名挂载
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx

#通过-v 卷名:容器内路径
#查看具体位置
docker volume inspect juming-nginx 根据自己的卷名进行修改

docker容器内的卷,没有指定目录的情况下都是在/var/lib/docker/volumes/xxxx/_data

#如何确定是具名挂载还是匿名挂载,还是指定路径挂载
-v 容器内路径       #匿名挂载
-v 卷名:容器内路径   #具名挂载
-v /宿主机路径::容器内路径    #指定路径挂载

扩展

#通过  -v 容器内路径:ro rw 改变读写权限
ro  readonly  #只读
rw  readwrite #可读可写

#一旦这个了设置了容器权限,容器对我们挂载出来的内容就有限定了
docker run -d -P --name nginx02 -v juming-ngin:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-ngin:/etc/nginx:rw nginx

#ro 只要看到ro就说明这个路径只能通过宿主机来操作,容器内部都是无法操作的

初识Dockerfile

Dockerfile就是用来构建docker镜像的构建文件!命令脚本!通过这个脚本可以生成镜像,镜像是一层层的,脚本是一个个的命令

#创建一个dockerfile文件,名字可以随机  建议dockerfile
#文件中的内容  指令(大写) 参数

FROM centos

VOLUME ["volume01","volume02"]

CMD echo "-----end------"

CMD /bin/bash

数据卷容器

多个mysql同步数据!

image.png

docker run -it --name docker01 kuangshen/centos:1.0    #创建容器并运行

docker run -it --name docker02 --volumes-from docker01 kuangshen/centos:1.0   #将docker02挂载与docker01 可以实现数据的同步

image.png

多个mysql可以实现数据共享

相关文章
|
8天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
31 2
|
5天前
|
运维 Cloud Native 虚拟化
一文吃透云原生 Docker 容器,建议收藏!
本文深入解析云原生Docker容器技术,涵盖容器与Docker的概念、优势、架构设计及应用场景等,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
一文吃透云原生 Docker 容器,建议收藏!
|
6天前
|
缓存 监控 开发者
掌握Docker容器化技术:提升开发效率的利器
在现代软件开发中,Docker容器化技术成为提升开发效率和应用部署灵活性的重要工具。本文介绍Docker的基本概念,并分享Dockerfile最佳实践、容器网络配置、环境变量和秘密管理、容器监控与日志管理、Docker Compose以及CI/CD集成等技巧,帮助开发者更高效地利用Docker。
|
8天前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
8天前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用
|
8天前
|
安全 持续交付 Docker
微服务架构和 Docker 容器化部署的优点是什么?
微服务架构和 Docker 容器化部署的优点是什么?
|
17天前
|
Kubernetes 监控 开发者
掌握容器化:Docker与Kubernetes的最佳实践
【10月更文挑战第26天】本文深入探讨了Docker和Kubernetes的最佳实践,涵盖Dockerfile优化、数据卷管理、网络配置、Pod设计、服务发现与负载均衡、声明式更新等内容。同时介绍了容器化现有应用、自动化部署、监控与日志等开发技巧,以及Docker Compose和Helm等实用工具。旨在帮助开发者提高开发效率和系统稳定性,构建现代、高效、可扩展的应用。
|
13天前
|
关系型数据库 MySQL API
|
30天前
|
存储 Docker 容器
docker中挂载数据卷到容器
【10月更文挑战第12天】
68 5
|
10天前
|
运维 开发者 Docker
Docker Compose:简化容器化应用的部署与管理
Docker Compose:简化容器化应用的部署与管理