1

アプリ エンジンのカスタム ランタイム環境を設定するために、以下の Dockerfile を使用しています。

FROM ubuntu:latest   
RUN apt-get update -y  
RUN apt-get install -y python-pip build-essential libssl-dev libffi-dev python-dev libxml2-dev libxslt1-dev xmlsec1

RUN apt-get install -y curl unzip
RUN curl https://dl.google.com/dl/cloudsdk/release/google-cloud-sdk.tar.gz > /tmp/google-cloud-sdk.tar.gz  
RUN mkdir -p /usr/local/gcloud  
RUN tar -C /usr/local/gcloud -xvf /tmp/google-cloud-sdk.tar.gz  
RUN /usr/local/gcloud/google-cloud-sdk/install.sh

RUN curl https://storage.googleapis.com/appengine-sdks/featured/google_appengine_1.9.40.zip > /tmp/google_appengine_1.9.40.zip  
RUN unzip /tmp/google_appengine_1.9.40.zip -d /usr/local/gae

ENV PATH $PATH:/usr/local/gcloud/google-cloud-sdk/bin  
ENV PATH $PATH:/usr/local/gae/google_appengine/
COPY . /app  
WORKDIR /app  
EXPOSE 80  
RUN pip install -r requirements.txt  
ENTRYPOINT gunicorn -b :$PORT main:app

問題:

問題は、アプリ エンジン ライブラリの zip ファイルをダウンロードして解凍し、PATH 変数に追加したにもかかわらず、指定されたエントリ ポイントを介してアプリを実行しているときに、インポート エラーが発生することです。GAE の docker イメージについて読んだところ、デフォルトではルート プロファイルで実行されることがわかったので、問題はルート プロファイルの PATH 変数の更新と他のプロファイルでのアクセスに関連しているとは思いません。

以下はスタックトレースです

File "/usr/local/lib/python2.7/dist-packages/gunicorn/util.py", line 357, in import_app  
__import__(module)
File "/app/main.py", line 6, in <module>
from com.sears.mrp.handlers.ProductRuleHandler import ProductRuleHandler  
File "/app/com/sears/mrp/handlers/ProductRuleHandler.py", line 1, in <module>
from google.appengine.ext import ndb  
ImportError: No module named google.appengine.ext
[2016-11-28 09:10:17 +0000] [10] [INFO] Worker exiting (pid: 10)
[2016-11-28 09:10:17 +0000] [5] [INFO] Shutting down: Master
[2016-11-28 09:10:17 +0000] [5] [INFO] Reason: Worker failed to boot.*


If any one has faced this issue before please provide solution, I'm clueless on that to try more.
4

1 に答える 1

1

これは、Dockerfile の最初の行になります。

FROM gcr.io/google_appengine/python-compat-multicore

標準 (ランタイム: python27) App Engine ランタイムで 7 つの API をサポートする App Engine API をサポートする基本イメージが必要です。

Dockerfile で指定されたランタイムで使用できないアプリ エンジン API が原因で、上記のインポート エラーが発生しています。

詳細はこちらをご覧ください

于 2016-11-28T12:38:03.107 に答える