使用Dockerfile生成docker镜像和容器的方法记录

一、相关介绍

Docker 是一个开源的容器化平台,其中的主要概念是容器和镜像。
容器是 Docker 的运行实例。 它是一个独立并可执行的软件包,包含了应用程序及其依赖的所有组件(如代码、运行时环境、系统工具、库文件等)。容器可以在不同的环境中运行,具有隔离性和可移植性,不会受到底层系统或其他容器的影响。

镜像是一个只读的模板,用于创建容器。 它包含了一个完整的文件系统,其中包含应用程序和所有的依赖项。镜像可以被复制和分享,用于在不同的环境中创建多个相同的容器实例。每个容器都是基于镜像创建的,它们与镜像共享基础文件系统,但会在其上添加一个可写的文件系统层,使得容器是可变的。

镜像可以通过 Dockerfile 定义和构建,Dockerfile 是一个文本文件,包含了一系列的指令和配置,用于自动化地构建镜像。使用 Dockerfile,你可以定义容器所需的操作系统、软件包、环境变量、文件副本等。

个人看法:

docker用的还不熟练,也正因此好好做个记录。docker主要是通过Dockerfile生成镜像形成一个独立的工作空间,可移植性好,部署方便。目前对于怎么配置docker命令环境还不了解,也没多少专业的介绍,记录一下相关操作方法。

二、操作方法

1、打docker上传

①准备Dockerfile文件

FROM 从已有镜像继承

或者从装库等基本环境配置Dockerfile,一般要建立工作文件夹,把要用到的代码工具COPY到工作文件夹下

②在Dockerfile同一路径下打镜像,REPOSITORY:TAG 表示镜像名标签,注意最后要加点 .
python 复制代码
docker build -t REPOSITORY:TAG .
③查看镜像是否生成
python 复制代码
docker images
④打标签,给镜像换规范名称或其他名称,对应REPOSITORY:TAG
python 复制代码
docker tag old:old new:new
⑤把生成的镜像推到平台,这个目的是在平台上调用生成的镜像,直接生推还容易出问题,感觉是非必要操作
python 复制代码
docker push REPOSITORY:TAG

2、基于修改现有容器进行更新上传

①查找容器
python 复制代码
docker ps -a

或检索关键字xxx

python 复制代码
docker images | grep xxx
②进入要修改的容器
python 复制代码
docker run -it REPOSITORY:TAG /bin/bash
③查找需要修改的文件,a编辑,esc切换编辑
python 复制代码
vim file
④退出当前镜像,提交修改后的镜像
python 复制代码
docker commit -m='description' -a='author' REPOSITORY:TAG
⑤push上平台,如有需求

3、镜像测试,直接在镜像内测试代码,或者在平台执行查看日志,查看日志命令

python 复制代码
kubectl get pods -n xxx-theme
kubectl logs -f -n xxx-theme job-xxx

ctrl + c退出查看日志

4、镜像删除

①先删除容器,查看运行容器名 CONTAINER_ID、CONTAINER_NAME
python 复制代码
docker ps

或查看所有容器

python 复制代码
docker ps -a
②先停止运行容器
python 复制代码
docker stop CONTAINER_ID/CONTAINER_NAME
③删除容器
python 复制代码
docker rm CONTAINER_ID/CONTAINER_NAME
④删除镜像 IMAGE_ID
python 复制代码
docker rmi IMAGE_ID
相关推荐
MonkeyKing_sunyuhua18 分钟前
ubuntu22.04 docker-compose安装postgresql数据库
数据库·docker·postgresql
追风林1 小时前
mac m1 docker本地部署canal 监听mysql的binglog日志
java·docker·mac
€☞扫地僧☜€2 小时前
docker 拉取MySQL8.0镜像以及安装
运维·数据库·docker·容器
茶馆大橘2 小时前
微服务系列六:分布式事务与seata
分布式·docker·微服务·nacos·seata·springcloud
全能全知者3 小时前
docker快速安装与配置mongoDB
mongodb·docker·容器
阿尔帕兹5 小时前
构建 HTTP 服务端与 Docker 镜像:从开发到测试
网络协议·http·docker
ZHOU西口6 小时前
微服务实战系列之玩转Docker(十八)
分布式·docker·云原生·架构·数据安全·etcd·rbac
景天科技苑9 小时前
【云原生开发】K8S多集群资源管理平台架构设计
云原生·容器·kubernetes·k8s·云原生开发·k8s管理系统
wclass-zhengge10 小时前
K8S篇(基本介绍)
云原生·容器·kubernetes
颜淡慕潇10 小时前
【K8S问题系列 |1 】Kubernetes 中 NodePort 类型的 Service 无法访问【已解决】
后端·云原生·容器·kubernetes·问题解决