一、理论基础
我们今天需要利用docker制作一个镜像,便于分享与使用
那么,我们制作一个镜像需要什么,要准备哪些“原材料”?
比如,我们用Java编写了一个应用,并打包成jar
第一,我们需要编写一个Dockerfile,里面含制作镜像的command。而后docker的builder根据指令,拿着指令和app.jar制作镜像
镜像里面有基础环境(例如jdk),软件包,启动命令
二、实验过程
2.1 预备
实验准备:
- 一个jar包,建议具有运行现象
- 上传到服务器(我的是centos)
- 有docker
docker安装的前置知识见我之前的bolg:
https://blog.youkuaiyun.com/m0_73118788/article/details/146986119?fromshare=blogdetail&sharetype=blogdetail&sharerId=146986119&sharerefer=PC&sharesource=m0_73118788&sharefrom=from_link
2.2 制作镜像
- 完成dockfile
vim dockerfile
按i
进入插入模式,写入如下命令
FROM openjdk:17
LABEL author=your_name
COPY app.jar /app.jar
EXPOSE 8881
ENTRYPOINT ["java","-jar","/app.jar"]
`Esc`退出,`:wq`保存并返回命令行
-
FROM openjdk:17
此指令的作用是指定基础镜像。在 Docker 里构建镜像时,要基于某个已有的镜像来开展,这里选择的是openjdk:17
,也就是包含 OpenJDK 17 运行环境的官方镜像。这意味着后续构建出的镜像会拥有 OpenJDK 17 的运行环境。 -
LABEL
指令用于给镜像添加元数据。这里添加了一个名为author
的标签,其值为your_name
。你可以借助这个标签来记录镜像的作者信息,后续可以使用docker inspect
命令查看这些元数据。 -
COPY
指令的用途是把本地文件或者目录复制到镜像中。在这个指令里,将本地的app.jar
文件复制到了镜像的根目录下,文件名为app.jar
。一般而言,app.jar
是 Java 应用程序的可执行 JAR 文件。 -
EXPOSE
指令的作用是声明容器运行时会监听的端口。这里声明容器会监听 8881 端口。不过要注意,此指令仅仅是声明,并不会自动将该端口映射到宿主机上。若要进行端口映射,需要在运行容器时使用-p
参数。 -
ENTRYPOINT
指令用来指定容器启动时要执行的命令。这里指定容器启动时会执行java -jar /app.jar
命令,也就是运行之前复制到镜像里的app.jar
文件。使用数组形式的ENTRYPOINT
可以避免 shell 解析带来的问题,确保命令能按照预期执行。
dockerfile里面指令知识如下:
2. 开始制作
docker build -f Dockerfile -t my_javatest:v1.0 ./
-f
是 --file 的简写形式,该参数用于指定构建镜像时所使用的 Dockerfile 文件。这里指定使用当前目录下名为 Dockerfile 的文件。若不使用 -f 参数,docker build 命令默认会在当前目录下查找名为 Dockerfile 的文件。
-t
是 --tag 的简写形式,该参数用于为构建好的镜像添加标签。标签由两部分组成,用冒号分隔,前面的 my_javatest 是镜像的名称,后面的 v1.0 是镜像的版本号。添加标签后,你就能更方便地识别和管理这个镜像。
./
这是构建上下文的路径。构建上下文指的是在构建镜像时,Docker 客户端会将该路径下的所有文件和目录发送给 Docker 守护进程,供 Dockerfile 中的指令使用(ATTANTION:dockerfile里面COPY app.jar /app.jar,app.jar是相对路径,相对什么?这里./
就表示相对root的./,即root目录)。这里的 ./ 表示当前目录,也就是说 Docker 会把当前目录下的所有文件和目录作为构建上下文。
如此便有了镜像,下图查看
2.3 使用自制镜像
docker run -d -p 服务器端口:dockerfile写的本容器端口 镜像