无法在 alpine docker 容器上安装 pyorc

Failed to install pyorc on alpine docker container

出现编译错误 - 这取决于 ORC 二进制文件。

In file included from src/_pyorc/_pyorc.cpp:1:
src/_pyorc/Reader.h:7:10: fatal error: 'orc/OrcFile.hh' file not found
#include "orc/OrcFile.hh"
         ^~~~~~~~~~~~~~~~
1 error generated.
error: command 'clang' failed with exit status 1

如果我也单独编译apache-orc,我怎样才能将它引用到PyOrc Pip安装?

任何人有任何解决方案或想法我们如何在 alpine 容器中安装 pyorc 包。

我在使用 ubuntu 和普通 python docker 图像时遇到问题。

Docker 图片:FROM python:3.7-alpine

我使用了 Docker 多阶段构建:

# Dockerfile

FROM python:3.7.3
WORKDIR /app
RUN pip install pyorc -t .

FROM python:3.7.3-alpine
WORKDIR /app
RUN apk add --no-cache --virtual .build-deps g++ musl-dev gcompat
COPY --from=0 /app .

它似乎有效:

$ docker build -t test .
$ docker run -it --rm test python
Python 3.7.3 (default, Jun 27 2019, 22:53:21)
[GCC 8.3.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import pyorc
>>>
>>> with open("./new_data.orc", "wb") as data:
...     with pyorc.Writer(data, "struct<col0:int,col1:string>") as writer:
...         writer.write((1, "ORC from Python"))
...
>>> from pathlib import Path
>>> Path("./new_data.orc").read_bytes()
b'ORC\x1d\x00\x00\n\x0c\n\x04\x00\x00\x.....'

作者 Noirello, 给我 guidelines/direction 如下:

对于 Alpine,必须从源代码安装它。 文档中有一些说明如何操作:pyOrc-Docs

我会使用一个多阶段的 Dockerfile 来构建 pyorc,然后将 wheel 与您的应用程序的其余部分一起安装到干净的 Alpine 映像中。

像这样:

FROM python:3.8.3-alpine AS builder
RUN apk add gcc g++ musl-dev cmake make
ARG VERSION=0.3.0

RUN mkdir build
WORKDIR /build
RUN pip install pybind11 wheel
RUN pip download --no-binary :all: --no-deps pyorc==${VERSION} && tar -xvf *.tar.gz
RUN cd pyorc-${VERSION} && python3 setup.py build_orc
RUN cd pyorc-${VERSION} && python3 setup.py bdist_wheel

FROM python:3.8.3-alpine
ARG VERSION=0.3.0

COPY --from=builder /build/pyorc-${VERSION}/dist/pyorc-${VERSION}-*.whl /tmp/
# Adding libstdc++, because the wheel expects that the libstdc++.so is presented on the system.
# Adding tzdata, because the ORC C++ lib needs to have a localtime set.
RUN apk add libstdc++ tzdata
# Setting localtime to UTC.
RUN ln -fs /usr/share/zoneinfo/Etc/UTC /etc/localtime
RUN pip install /tmp/pyorc-${VERSION}-*.whl && rm -rf /tmp/pyorc-${VERSION}-*.whl
# Rest of your custom image...