Cryptic AttributeError:'tuple'对象没有属性'setsockopt'错误消息

时间:2018-01-23 16:19:19

标签: python docker nameko

我正在尝试部署dockerized python( nameko )应用程序。

一切都按预期工作,我试图通过GET方法访问其中一个模块。在那里,我收到了一个非常神秘的错误:

...
File "/usr/local/lib/python3.6/site-packages/eventlet/wsgi.py", line 347,
in setup conn.setsockopt(socket.IPPROTO_TCP, socket.TCP_QUICKACK, True)

AttributeError: 'tuple' object has no attribute 'setsockopt'

我知道我的代码不是问题,因为它已经在一台没有问题的暂存机器上启动并运行(至少是那种)。

我正在使用的Dockerfile看起来像这样(请注意你!):

FROM python:3.5

EXPOSE 8000

CMD ["./run.sh"]

RUN adduser --uid 1000 --disabled-password --gecos '' --home /home/devuser devuser

WORKDIR /app

RUN apt-get update && apt-get install -y --no-install-recommends \
    build-essential \
    libxml2-dev \
    zlib1g-dev \
    libssl-dev \
    libxslt1-dev \
    netcat && \
    pip install --upgrade pip && \
    rm -rf /var/lib/apt/lists/* \
    rm -f /var/cache/apt/archives/*.deb

COPY requirements.txt /app/requirements.txt
RUN pip install --no-cache-dir -r /app/requirements.txt

COPY . /app

RUN chown devuser.devuser -R .
USER devuser

我和我的升降机没什么不同,所以我很想知道......

1 个答案:

答案 0 :(得分:1)

这是bug in nameko的症状,由eventlet library的变化引起。

解决方案是升级到nameko 2.8.3,它将要安装的eventlet版本固定在0.16.1 - 0.22.0的范围内。