Dokerfile
FROM centos:latest
MAINTAINER "lcy@qq.com"
ADD /software/jdk8/jdk1.8.0_191 /jdk/jdk1.8.0_191
ENV JAVA_HOME /jdk/jdk1.8.0_191
ENV PATH $PATH:$JAVA_HOME/bin
构建镜像报错如下:
root@iZwz9hb3esnbp5jod6mregZ:/data/dockerFiles# docker build -t centos_jdk8:base . -f Dockerfile
Sending build context to Docker daemon 2.048kB
Step 1/5 : FROM centos:latest
latest: Pulling from library/centos
6910e5a164f7: Pull complete
Digest: sha256:4062bbdd1bb0801b0aa38e0f83dece70fb7a5e9bce223423a68de2d8b784b43b
Status: Downloaded newer image for centos:latest
---> 831691599b88
Step 2/5 : MAINTAINER "lcy@qq.com"
---> Running in 32a4b625801c
Removing intermediate container 32a4b625801c
---> ca8f874eca03
Step 3/5 : ADD /software/jdk8/jdk1.8.0_191 /jdk/jdk1.8.0_191
ADD failed: stat /var/lib/docker/tmp/docker-builder964944550/software/jdk8/jdk1.8.0_191: no such file or directory
经查阅网络发现应该是如下原因
COPY 本机目录 容器目录
本机目录不能使用绝对路径,因为它本身就是一个相对路径
本机目录直接从当前目录开始,所有需要复制的文件放在当前目录
COPY test/1 /home/1
只会复制本机的1目录下所有文件,而不会创建1目录,所以后面需要指定
原文链接:https://blog.csdn.net/u010627840/java/article/details/103635038
然后ADD含有直接解压的功能,所以将dockerfile文件修改为:主要修改点为复制tar包到当前目录下,然后对应更改COPY 为ADD自动解压到容器
FROM centos:latest
MAINTAINER "lcy@qq.com"
ADD jdk-8u191-linux-x64.tar.gz /jdk/
ENV JAVA_HOME /jdk/jdk1.8.0_191
#ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar(这一行不要也可)
ENV PATH $PATH:$JAVA_HOME/bin
镜像构建成功
root@iZwz9hb3esnbp5jod6mregZ:/data/dockerFiles# docker build -t base . -f Dockerfile
Sending build context to Docker daemon 191.8MB
Step 1/5 : FROM centos:latest
---> 831691599b88
Step 2/5 : MAINTAINER "lcy@qq.com"
---> Running in 065bada3c33f
Removing intermediate container 065bada3c33f
---> 1b6a7d23e897
Step 3/5 : ADD jdk-8u191-linux-x64.tar.gz /jdk/
---> 577ac67983cc
Step 4/5 : ENV JAVA_HOME /jdk/jdk1.8.0_191
---> Running in 3b8b41547601
Removing intermediate container 3b8b41547601
---> 357b5f1c555f
Step 5/5 : ENV PATH $PATH:$JAVA_HOME/bin
---> Running in 98602b852681
Removing intermediate container 98602b852681
---> d095141b6cfa
Successfully built d095141b6cfa
Successfully tagged base:latest
root@iZwz9hb3esnbp5jod6mregZ:/data/dockerFiles# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
base latest d095141b6cfa 5 seconds ago 612MB
运行含有jdk的centos镜像(注意一定要加 -it 否则起不来或者起来就停掉了)
docker run -d -it --name=jdk base
进入容器java,javac均已经ok
关于ADD和COPY的区别可以参考https://www.cnblogs.com/zdz8207/p/linux-docker-add-copy.html,如下:
docker Dockerfile指令ADD和COPY的区别,添加目录方法
ADD指令的功能是将主机构建环境(上下文)目录中的文件和目录、以及一个URL标记的文件 拷贝到镜像中。
其格式是: ADD 源路径 目标路径
#把当前config目录下所有文件拷贝到/config/目录下
ADD config/ /config/
ADD test1.txt test1.txt
ADD test1.txt test1.txt.bak
ADD test1.txt /mydir/
ADD data1 data1
ADD data2 data2
ADD zip.tar /myzip
有如下注意事项:
1、如果源路径是个文件,且目标路径是以 / 结尾, 则docker会把目标路径当作一个目录,会把源文件拷贝到该目录下。
如果目标路径不存在,则会自动创建目标路径。
2、如果源路径是个文件,且目标路径是不是以 / 结尾,则docker会把目标路径当作一个文件。
如果目标路径不存在,会以目标路径为名创建一个文件,内容同源文件;
如果目标文件是个存在的文件,会用源文件覆盖它,当然只是内容覆盖,文件名还是目标文件名。
如果目标文件实际是个存在的目录,则会源文件拷贝到该目录下。 注意,这种情况下,最好显示的以 / 结尾,以避免混淆。
3、如果源路径是个目录,且目标路径不存在,则docker会自动以目标路径创建一个目录,把源路径目录下的文件拷贝进来。
如果目标路径是个已经存在的目录,则docker会把源路径目录下的文件拷贝到该目录下。
4、如果源文件是个归档文件(压缩文件),则docker会自动帮解压。
----------------
ADD从一开始就是Docker 的一部分,并且支持一些传统的技巧,而不仅仅是从build 上下文中复制文件。
ADD指令可以让你使用URL作为<src>参数。当遇到URL时候,可以通过URL下载文件并且复制到<dest>。
ADD http://foo.com/bar.go /tmp/main.go
以上文件会通过制定的URL下载下来,并且添加到容器的文件系统中的/tmp/main.go路径中。另外一种形式是让你简单地制定目的目录为下载文件:
ADD http://foo.com/bar.go /tmp/
因为<dest>以 / 结尾。Docker 会从URL推断文件名,并且添加到指定目录。在这个案例中,一个名叫/tmp/bar.go的文件会被添加到容器的文件系统。
ADD的另外一个特性是有能力自动解压文件。如果<src>参数是一个可识别的压缩格式(tar, gzip, bzip2, etc)的本地文件(所以实现不了同时下载并解压),就会被解压到指定容器文件系统的路径<dest>。
ADD /foo.tar.gz /tmp/
上述指令会使foo.tar.gz压缩文件解压到容器的/tmp目录。
URL下载和解压特性不能一起使用。任何压缩文件通过URL拷贝,都不会自动解压。
目前ADD指令有点让人迷惑,有时候解压文件,有时候不解压文件,如果你想拷贝一个压缩文件,你会以为地解压。如果文件是某种不能识别的压缩文件,如果你想解压,你又会意外地复制它。
这种解释似乎是ADD尝试做的太多了,让用户有些疑惑。很明显,没人想要打破向后兼容性。所以决定新增一个行为更加明确的指令。
COPY和ADD相似,但是功能少一些。
在Docker 1.0发布时候,包括了新指令COPY。不像是ADD,COPY 更加直接了当,只复制文件或者目录到容器里。
COPY不支持URL,也不会特别对待压缩文件。如果build 上下文件中没有指定解压的话,那么就不会自动解压,只会复制压缩文件到容器中。
COPY是ADD的一种简化版本,目的在于满足大多数人“复制文件到容器”的需求。
Docker 团队的建议是在大多数情况下使用COPY。拷贝文件的原则:使用COPY(除非你明确你需要ADD)