Docker镜像制作

一、容器转为镜像

docker commit 容器id 镜像名称:版本号

docker save -o 压缩文件名称 镜像名称:版本号

docker load -i 压缩文件名称

注意:容器原本挂载的文件不会被打包到镜像中

示例

bash 复制代码
[root@docker_dev ~]# docker ps -a 
CONTAINER ID   IMAGE       COMMAND                  CREATED         STATUS                      PORTS     NAMES               c_nginx
b4432a89096e   tomcat      "catalina.sh run"        17 hours ago    Exited (143) 16 hours ago             c_tomcat
#用c_tomcat容器制作一个1.0版本的镜像
[root@docker_dev ~]# docker commit b4432a89096e c_tomcat_imgae:1.0 
sha256:6d650eb0174fba52ff49228ec3424fa5c971ee6c1e9a120bffcfc1f0f4c04ba9
#这块打包后,我会把原本镜像删除方便等会load验证
[root@docker_dev ~]# docker images
REPOSITORY       TAG       IMAGE ID       CREATED              SIZE
c_tomcat_imgae   1.0       6d650eb0174f   About a minute ago   537MB
[root@docker_dev ~]# docker save -o tomca_image.tar c_tomcat_imgae
[root@docker_dev ~]# docker load -i tomca_image.tar 
cc3197f6854c: Loading layer [==================================================>]  127.8MB/127.8MB
Loaded image: c_tomcat_imgae:1.0
[root@docker_dev ~]# docker images
REPOSITORY       TAG       IMAGE ID       CREATED          SIZE
c_tomcat_imgae   1.0       6d650eb0174f   10 minutes ago   537MB

二、Dockerfile制作镜像

指令:

FROM:基础镜像
LABLE:镜像描述信息
COPY:从 Docker 宿主机复制文件至创建的新镜像文件

复制目录的时候,目录下面的文件会被递归复制过去

ADD:类似于 COPY 指令,ADD 支持 tar 文件和 URL 路径
WORKDIR:用于为 Dockerfile 中 RUN、CMD、ENTRYPOINT、COPY、ADD 指定设定工作目录
VOLUME:数据卷
EXPOSE:为容器打开指定的监听端口以实现与外部通信
ENV:用于为镜像定义所需的环境变量,可以被 Dockerfile 文件中其他命令调用
RUN:docker build 镜像构建的时候需要执行的 shell 命令
CMD:启动容器指定默认要运行的程序或命令
ENTRYPOINT:类型 CMD 指令的功能,用于为容器指定默认运行程序或命令

注意CMD 和 ENTRYPOINT 同时存在 Dockerfile 中时,CMD的值会当做参数传递给ENTRYPOINT

HEALTHCHECK:健康检查
SHELL:指定运行 RUN、CMD、ENTRYPOINT 的 shell 程序
STOPSIGNAL:给主进程发送信号
ARG:docker build 过程中的参数
ONBUILD:用于在 Dockerfile 中定义一个触发器

示例:

搭建一个centos7的基础安装环境,并且安装vim

bash 复制代码
[root@docker_dev docker-files]# cat centos-dockerfile-vim 
FROM centos:7
run echo "nameserver 8.8.8.8" > /etc/resolv.conf \
    echo "nameserver 114.114.114.114" >> /etc/resolv.conf \
    rm -f /etc/yum.repos.d/*.repo \
    curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo \
    sed -i 's#http://mirrors.aliyuncs.com#https://mirrors.aliyun.com#g' /etc/yum.repos.d/CentOS-Base.repo \ 
    sed -i 's#http://mirrors.cloud.aliyuncs.com#https://mirrors.aliyun.com#g' /etc/yum.repos.d/CentOS-Base.repo \
    yum clean all \
    yum makecache fast \
    yum install -y vim
workdir /usr
cmd /bin/bash
相关推荐
上海蓝色星球4 小时前
迈向智慧电网新纪元:上海蓝色星球数字孪生变电主子站系统
运维·数据库
logic_56 小时前
静态路由配置
运维·服务器·网络
zhuzewennamoamtf7 小时前
Linux内核platform抽象、数据结构、内核匹配机制
linux·运维·数据结构
门思科技7 小时前
企业级 LoRaWAN 网关远程运维方案对比:VPN 与 NPS FRP 的技术与安全差异分析
运维·网络·安全
云和数据.ChenGuang7 小时前
Deepseek 持续迭代的模型
运维·运维技术·数据库运维工程师·运维教程
物联网软硬件开发-轨物科技7 小时前
【轨物方案】聚焦锯床设备智能化升级,打造工业互联网新范式
运维·科技·物联网
运维栈记7 小时前
如何排错运行在Kubernetes集群中的服务?
云原生·容器·kubernetes
suzhou_speeder8 小时前
企业数字化网络稳定运行与智能化管理解决方案
运维·服务器·网络·交换机·poe·poe交换机
Linux编程用C8 小时前
Docker+Vscode搭建(本地/远程)开发环境
vscode·后端·docker
RisunJan8 小时前
Linux命令-grpck命令(验证和修复组配置文件(`/etc/group` 和 `/etc/gshadow`)完整性的工具)
linux·运维·服务器