dockers-系统学习-镜像

dockers-系统学习-镜像


一、Docker 镜像原理

1.1、操作系统组成部分

在这里插入图片描述

1.2、镜像原理

  1. Docker镜像是由特殊的文件系统叠加而成
  2. 最底端是 bootfs,并使用宿主机的bootfs
  3. 第二层是 root文件系统rootfs,称为base image
  4. 然后再往上可以叠加其他的镜像文件
  5. 统一文件系统(Union File System)技术能够将不同的层整合成一个文件系统,为这些层提供了一个统一的视角,这样就隐藏了多层的存在,在用户的角度看来,只存在一个文件系统。
  6. 一个镜像可以放在另一个镜像的上面。
    1. 位于下面的镜像称为父镜像
    2. 最底部的镜像成为基础镜像
  7. 当从一个镜像启动容器时,Docker会在最顶层加载一个读写文件系统作为容器

在这里插入图片描述

1.3、问题思考

1.3.1、Docker 镜像本质是什么?

是一个分层文件系统

1.3.2、Docker 中一个centos镜像为什么只有200MB,而一个centos操作系统的iso文件要几个个G?

Centos的iso镜像文件包含bootfs和rootfs,而docker的centos镜像复用操作系统的bootfs,只有rootfs和其他镜像层

1.3.3、Docker 中一个tomcat镜像为什么有500MB,而一个tomcat安装包只有70多MB?

由于docker中镜像是分层的,tomcat虽然只有70多MB,但他需要依赖于父镜像和基础镜像,所有整个对外暴露的tomcat镜像大小500多MB

二、Docker 镜像如何制作?

  1. 将容器转为镜像
  2. 使用dockerfile转为镜像

2.1、容器转为镜像

2.1.1、使用的命令

# 创建镜像
docker commit -m="提交的描述信息" -a="镜像作者" 容器id 新镜像名称:版本号
# 创建镜像压缩文件
docker save -o 压缩文件名称 镜像名称:版本号
# 解压镜像压缩文件
docker load –i 压缩文件名称

在这里插入图片描述

注意:

挂载的目录(数据卷目录)是不会保存数据的

举例:

容器c1的挂载的目录有个a.txt,那么我们将c1转为镜像,镜像里面是没有a.txt的。

2.1.2、将本地c1容器转为镜像

创建并启动容器

docker run -it --name jx  -v /root/data5:/root/data-container redis:latest

在挂载的目录中创建数据a.txt

在这里插入图片描述

创建镜像

docker commit jx redis-ylx:1.0

在这里插入图片描述

创建镜像压缩文件

docker save -o redis-ylx-1.0.tar redis-ylx:1.0

在这里插入图片描述

删掉原先的redis-ylx镜像

docker rmi redis-ylx:1.0

解压镜像压缩文件

docker load –i  redis-ylx-1.0.tar

在这里插入图片描述

验证挂载的目录(数据卷目录)是不会保存数据

docker run -it --name jx2 redis-ylx:1.0 

在挂载的目录中,没有a.txt

在这里插入图片描述

三、Dockerfile概念

1. 是一个文本文件
2. 包含了一条条的指令
3. 每一条指令都会在 docker 上新建一层,基于基础镜像,最终构建出一个新的镜像
	1. 过多无意义的层,会造成镜像膨胀过大。
	2. 以 && 符号连接命令,这样执行后,只会创建 1 层镜像。

四、Dockerfile作用

1. 对于开发人员:可以为开发团队提供一个完全一致的开发环境
2. 对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了
3. 对于运维人员:在部署时,可以实现应用的无缝移植

五、Dockerfile关键字

在这里插入图片描述

六、 Dockerfile创建镜像

##4.1、案例1–自定义centos镜像

要求

1. 默认登录路径为 /user
2. 	可以使用vim

总体过程

1. 	定义父镜像:FROM centos
2. 	定义作者信息:MAINTAINER ylx ylx@qq.cn
3. 	执行安装vim命令: RUN yum install -y vim
4. 	定义默认的工作目录:WORKDIR /user
5. 	定义容器启动执行的命令:CMD /bin/bash
6. 	通过dockerfile构建镜像:docker bulid –f dockerfile文件路径 –t 镜像名称:版本 

01、步骤1–创建dockerfile文件

1. 	mkdir -p /root/docker_files 
2. 	cd /root/docker_files
3. 	vim centos_dockerFile

内容如下
FROM centos

MAINTAINER ylx ylx@qq.cn

RUN yum install -y vim

WORKDIR /user

CMD	/bin/bash

02、步骤2–通过dockerfile构建镜像

docker build -f /root/docker_files/centos_dockerFile -t centos_ylx:1.1 .

注:最后的一个“.” 是指上下文路径

在这里插入图片描述

03、步骤3–验证

docker run -it --name jx3 centos-ylx:1.1

在这里插入图片描述

4.2、案例2–自定义helloworld.jar镜像

要求

发布helloworld.jar项目

总体过程

1. 定义父镜像:FROM java:8
1. 定义作者信息:MAINTAINER ylx ylx@qq.com
1. 将jar包添加到容器: ADD helloworld.jar helloworld.jar
1. 定义容器启动执行的命令:CMD java –jar helloworld.jar
1. 通过dockerfile构建镜像:docker bulid –f dockerfile文件路径 –t 镜像名称:版本 .

01、步骤1–上传helloworld.jar

1. mkdir -p /root/docker_files 
2. cd /root/docker_files

在这里插入图片描述

02、步骤2–创建dockerfile文件

vim hello_world_dockerFile

内容如下

FROM java:8
MAINTAINER ylx ylx@qq.com
ADD  helloworld.jar hw.jar
CMD java -jar hw.jar

03、步骤3–通过dockerfile构建镜像

docker build -f /root/docker_files/hello_world_dockerFile -t helloworld:1.1 .

在这里插入图片描述

04、步骤4–验证

docker run -it --name c1  -p 8080:8080 helloworld:1.1

curl http://127.0.0.1:8080/sayHello

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以通过在 Docker Compose 文件中配置容器启动命令,在启动容器时执行 SQL 脚本。 以下是一个示例: ``` version: '3' services: db: image: your-image-name environment: MYSQL_ROOT_PASSWORD: password volumes: - ./sql:/docker-entrypoint-initdb.d ``` 在上面的示例中,我们将镜像名称配置为 `your-image-name`,并设置了环境变量 `MYSQL_ROOT_PASSWORD` 为 `password`。我们还将本地目录 `./sql` 挂载到容器内的 `/docker-entrypoint-initdb.d` 目录中。 当容器启动时,Docker 会执行该目录下的所有 SQL 脚本,并在数据库中执行。 请注意,上面的示例假定你正在使用一个兼容 MySQL 的数据库镜像,如果你使用的是其他数据库镜像,需要根据镜像的说明文档来配置容器启动命令。 ### 回答2: 使用Docker Compose 和达梦镜像启动执行 SQL 脚本是很简单的。首先,我们需要在本地创建一个 docker-compose.yml 文件,并设置合适的配置。 在 docker-compose.yml 文件中,我们需要定义一个服务,使用达梦镜像,并将 SQL 脚本挂载到容器中。例如: version: '3' services: dm-database: image: dm-db-image ports: - "5432:5432" volumes: - ./sql-scripts:/docker-entrypoint-initdb.d 在上面的例子中,我们定义了一个名为 dm-database 的服务,使用了 dm-db-image 镜像。我们将容器内部的 5432 端口映射到主机的 5432 端口,以便可以从本地连接到数据库。同时,我们将本地的 sql-scripts 目录挂载到容器的 /docker-entrypoint-initdb.d 目录下。这意味着,容器启动时,SQL 脚本将自动执行。 现在,我们可以使用 Docker Compose 启动这个服务。只需在终端中进入包含 docker-compose.yml 文件的目录,并运行以下命令: docker-compose up -d 这将启动 dm-database 服务,并在后台运行。 当容器启动后,它将执行挂载的 SQL 脚本。可以在.sql 脚本中编写 SQL 命令,以实现在数据库中创建表格、插入数据或者执行其他的操作。 总结起来,使用 Docker Compose 和达梦镜像启动执行 SQL 脚本非常简单。只需要通过 docker-compose.yml 文件定义服务,将 SQL 脚本挂载到容器中,然后使用 Docker Compose 启动服务即可。这样,我们就能够方便地管理和执行 SQL 脚本。 ### 回答3: Docker Compose是一个用于定义和运行多容器Docker应用程序的工具,它使用YAML文件来配置应用程序的服务、网络和卷。达梦镜像是用于在容器中运行达梦数据库的映像,可以通过Docker Compose来启动和管理。 要在达梦镜像中执行SQL脚本,可以按照以下步骤操作: 1. 首先,创建一个Docker Compose YAML文件,用于定义达梦数据库服务和相关配置。示例内容如下: ```yaml version: '3' services: dameng: image: dameng-db:latest ports: - "5432:5432" volumes: - ./scripts:/docker-entrypoint-initdb.d ``` 在这个示例中,我们创建了一个名为"dameng"的服务,使用了达梦数据库的镜像。同时,将宿主机上的`./scripts`目录挂载到容器内的`/docker-entrypoint-initdb.d`目录下,用于存放SQL脚本文件。 2. 在`./scripts`目录下创建SQL脚本文件,格式为`.sql`,比如命名为`init.sql`。在脚本文件中编写所需的SQL语句,比如创建表、插入数据等。 3. 运行以下命令启动应用程序: ``` docker-compose up -d ``` 这将启动Docker Compose配置文件中定义的服务,并自动将SQL脚本文件复制到达梦镜像内的`/docker-entrypoint-initdb.d`目录。 4. 达梦镜像在启动时会扫描`/docker-entrypoint-initdb.d`目录,如果发现有SQL脚本文件,将自动执行其中的SQL语句。 5. 当容器启动完成后,你可以通过连接到达梦数据库的方式来验证SQL脚本是否成功执行。比如使用数据库管理工具连接到`localhost:5432`,并执行相应的查询语句。 综上所述,通过使用Docker Compose来启动达梦镜像并执行SQL脚本,可以简化部署和管理达梦数据库的过程,并确保初始化脚本的自动执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值