Docker构建ubuntu:xenial问题

时间:2016-03-29 14:06:27

标签: python ubuntu jenkins docker dockerfile

我尝试在Jenkins中使用docker-py构建一个docker镜像。

脚本如下所示:

# Let's build the toolchain-base-image
from io import BytesIO
from docker import Client
from pprint import pprint
import sys

cli = Client(base_url="tcp://127.0.0.1:4243")
#cli = Client(base_url='unix://var/run/docker.sock')
GCC_VERSION_TAG="4_9"
with open("/path/to/docker-" + GCC_VERSION_TAG + "-gcc-base-image-dockerfile", mode="r") as dockerfile:
  f = BytesIO(dockerfile.read().encode('utf-8'))
  try:
      response = [pprint(line["stream"]) for line in cli.build(fileobj=f, nocache=False, rm=True, tag='gcc49/toolchain-base_'+GCC_VERSION_TAG, decode=True, pull=True)]
  except:
      raise IOError("Invalid Dockerfile!")
  if response != "None":
      pprint(response[0])

print "Create container"
container = cli.create_container(image='gcc49/toolchain-base_' + GCC_VERSION_TAG + ':latest',stdin_open=True, tty=True, volumes=['/ssd', '/opt', '/nfs/'], host_config=cli.create_host_config(binds=['/ssd:/ssd:rw','/opt/:/opt:ro','/nfs:/nfs:rw']))
print "Start container"
cli.start(container=container.get('Id'))
log_stream_list = []
[log_stream_list.append(l) for l in cli.logs(container, stream=True)]

print "".join(log_stream_list)

我的dockerfile如下所示:

FROM ubuntu:16.04
MAINTAINER Gino
ENV CMAKE_TOOLCHAIN_FILE /path/to/toolchainfile.toolchain
ENV SOURCE_DIR /path/to/src_root
RUN apt-get update 
RUN apt-get install -y python-cheetah build-essential gcc-4.9 cmake
RUN groupadd group
RUN useradd -G group -m -s /bin/bash user 
RUN echo "user:user" | chpasswd
ENV HOME /home/user
ENV SHELL /bin/bash
ENV JAVA_HOME /opt/jdk1.8.0_65/
RUN mkdir -p /home/user/docker-build
WORKDIR /home/user/docker-build
# Set permissions
RUN chown -R user:group /home/*
USER user
# Start build on run
ENTRYPOINT cmake -DBUILD_JAVA=0 -DCMAKE_BUILD_TYPE=DeveloperRelease -DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE} -DPROJECT_CONFIGURATION="project@${SOURCE_DIR}/dir" ${SOURCE_DIR} && make -j4

我的问题:

15:37:27 [docker-test_job] $ python /tmp/hudson5834793409651253293.py
15:37:29 u'Step 1 : FROM ubuntu:16.04\n'
15:37:29 Traceback (most recent call last):
15:37:29   File "/tmp/hudson5834793409651253293.py", line 15, in <module>
15:37:29     raise IOError("Invalid Dockerfile!")
15:37:29 IOError: Invalid Dockerfile!
15:37:29 Build step 'Execute Python script' marked build as failure
15:37:29 Stopping all containers
15:37:29 Finished: FAILURE

当我尝试使用ubuntu时:14.04它运行得很好。有人有个主意吗? 谢谢你的帮助!

更新:一些其他信息:Docker 1.5 + Ubuntu 12.04 LTS。 当我在控制台上运行时

docker build -t name/tag -f dockerfilename .

它也可以工作,并且docker按预期构建图像。

2 个答案:

答案 0 :(得分:1)

现在有效。我发现我不能使用pull=True。我认为返回码&gt; 0回来了,Jenkins将其解释为错误。谢谢你的帮助。 :)下面是有效的代码。

[pprint(line["stream"]) for line in cli.build(fileobj=f, nocache=False, rm=True, tag='gcc49/toolchain-base_'+GCC_VERSION_TAG, decode=True)]

更新

我错了。在上面一行我尝试匹配键“流”。但是如果docker拉出图像。没有这样的钥匙。

10:28:06  u'progress': u'[===================================>               ] 36.18 MB/50.84 MB',
10:28:06  u'progressDetail': {u'current': 36175872, u'total': 50841331},
10:28:06  u'status': u'Extracting'}

现在一切都很清楚。 :)

答案 1 :(得分:0)

我猜你需要提供Docker文件的路径(包括你的Dockerfile的名称),而在python脚本中,你似乎只提供了Dockerfile所在的目录。尝试更改部分

打开(“/ path / to / docker-”+ GCC_VERSION_TAG +“ - gcc-base-image”,mode =“r”)'

open(“/ path / to / docker-”+ GCC_VERSION_TAG +“ - gcc-base-image / dockerfilename”,mode =“r”)

看看它是否有效