standard_init_linux.go:178:exec用户进程导致“ exec格式错误”


78

码头工人开始抛出此错误:

standard_init_linux.go:178:exec用户进程导致“ exec格式错误”

每当我运行带有CMD或ENTRYPOINT的特定docker容器时,不考虑文件的任何更改,然后删除CMD或ENTRYPOINT。这是我一直在使用的docker文件,该文件在大约一个小时前运行良好:

FROM buildpack-deps:jessie

ENV PATH /usr/local/bin:$PATH

ENV LANG C.UTF-8

RUN apt-get update && apt-get install -y --no-install-recommends \
        tcl \
        tk \
    && rm -rf /var/lib/apt/lists/*

ENV GPG_KEY 0D96DF4D4110E5C43FBFB17F2D347EA6AA65421D
ENV PYTHON_VERSION 3.6.0

ENV PYTHON_PIP_VERSION 9.0.1

RUN set -ex \
    && buildDeps=' \
        tcl-dev \
        tk-dev \
    ' \
    && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \
    \
    && wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz" \
    && wget -O python.tar.xz.asc "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz.asc" \
    && export GNUPGHOME="$(mktemp -d)" \
    && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys "$GPG_KEY" \
    && gpg --batch --verify python.tar.xz.asc python.tar.xz \
    && rm -r "$GNUPGHOME" python.tar.xz.asc \
    && mkdir -p /usr/src/python \
    && tar -xJC /usr/src/python --strip-components=1 -f python.tar.xz \
    && rm python.tar.xz \
    \
    && cd /usr/src/python \
    && ./configure \
        --enable-loadable-sqlite-extensions \
        --enable-shared \
    && make -j$(nproc) \
    && make install \
    && ldconfig \
    \
    && if [ ! -e /usr/local/bin/pip3 ]; then : \
        && wget -O /tmp/get-pip.py 'https://bootstrap.pypa.io/get-pip.py' \
        && python3 /tmp/get-pip.py "pip==$PYTHON_PIP_VERSION" \
        && rm /tmp/get-pip.py \
    ; fi \
    && pip3 install --no-cache-dir --upgrade --force-reinstall "pip==$PYTHON_PIP_VERSION" \
    && [ "$(pip list |tac|tac| awk -F '[ ()]+' '$1 == "pip" { print $2; exit }')" = "$PYTHON_PIP_VERSION" ] \
    \
    && find /usr/local -depth \
        \( \
            \( -type d -a -name test -o -name tests \) \
            -o \
            \( -type f -a -name '*.pyc' -o -name '*.pyo' \) \
        \) -exec rm -rf '{}' + \
    && apt-get purge -y --auto-remove $buildDeps \
    && rm -rf /usr/src/python ~/.cache

RUN cd /usr/local/bin \
    && { [ -e easy_install ] || ln -s easy_install-* easy_install; } \
    && ln -s idle3 idle \
    && ln -s pydoc3 pydoc \
    && ln -s python3 python \
    && ln -s python3-config python-config

RUN pip install uwsgi

RUN mkdir /config

RUN mkdir /logs

ENV HOME /var/www

WORKDIR /config

ADD conf/requirements.txt /config

RUN pip install -r /config/requirements.txt

ADD conf/wsgi.py /config

ADD conf/wsgi.ini /config

ADD conf/__init__.py /config

ADD start.sh /bin/start.sh

RUN chmod +x /bin/start.sh

EXPOSE 8000

ENTRYPOINT ["start.sh", "uwsgi", "--ini", "wsgi.ini"]

Answers:


186

我忘了放

#!/bin/bash

在sh文件的顶部,问题已解决。


3
谢谢!经过一个小时的梳理,并十次检查架构(arm / x64等)是否匹配,您的答案才节省了一天!ps:对于像我这样的Windows用户创建linux docker,请不要忘记从文件中删除Windows换行符(\ r),否则错误将继续出现!
Maarten Kieft

使用此解决方案后,它可以正常工作,之前我遇到过同样的问题。
akshat thakar

7
我的“#!/ bin / bash”前面有一个空格
ArunTejCh

2
FFS!几个小时试图找出答案,这就是问题所在-请选择此作为答案!!!
亚历山德罗·马里亚尼

我以某种方式删除了#入口点的开头。真浪费时间。
粉碎

30

添加此代码

   #!/usr/bin/env bash

在脚本文件的顶部。


1
@akki入口点必须是可执行的。如果不是初始外壳文件,则导致该错误。
jjmerelo

很好,您可以挽救我的一天
肯尼·李

4

如果您尝试在arm64 / aarch64机器上运行x86构建的映像,则会发生这种情况。

您需要使用相应的架构来重建图像


1
谢谢!我最近将docker东西移到树莓派上的Kubernetes上了-忘记了不同的体系结构-必须更改我的所有图像以使用arm32v7或arm64v8。您为我指出了正确的方向!
MichaelEaton

2

造成这种情况的另一个可能原因是,该文件是否以Windows行尾(CRLF)保存。用Unix行尾(LF)保存它,然后将找到文件。


1

运行脱机加载的映像时,在RHEL 7.3,docker 17.05-ce中遇到了相同的问题。看来RHEL / CentOS的默认存储驱动程序已从设备映射器更改为覆盖。将驱动程序还原为devicemapper可以解决此问题。

dockerd --storage-driver=devicemapper

要么

/etc/docker/daemon.json
{
  "storage-driver": "devicemapper"
}

这是我唯一的工作解决方案。我更喜欢config解决方案,因为另一个解决方案会产生一个新的活动进程,并且可能只能临时修复它。
ST-DDT

0

扩展到可接受的答案:

对于高山(无bash)图像:

#!/bin/ash

在sh文件的顶部,可以解决此问题。



0

不能直接回答所提问题。虽然我在调用“ docker-compose up”启动nodejs应用程序时遇到错误。意识到在我的“ Dockerfile”中CMD ["./server.js"]

为了CMD ["npm","start"]解决这个问题,我用替换它,并解决了问题。希望有人为这个例外登陆这里可能会有用。


0

就我而言,我“清空”了我的ECS实例,然后再次“激活”了它们,此后错误消失了。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.