5

バックエンドを使用する AppEngine アプリケーションを、モジュールを使用するアプリケーションに変換しようとしています (Google の推奨に従って)。

backends_conversion.py app.yaml backends.yaml で backends.yaml を変換しました

appcfg.py の更新時に producer.yaml

バージョン「プロデューサー」が既に存在し、モジュール名を変更する必要があるというエラーを受け取りました。

私はそれをしませんでした (タスクキューのターゲットとしてモジュール名を使用するため)。代わりに、実行中のバックエンド バージョンを停止して削除しました。

モジュールをアップロードすると、その後機能しました。

ただし、(タスクキューを介した) タスクのキューイングは機能しません (つまり、モジュールのインスタンスが開始されません)。

また、ブラウザー (producer.appid.appspot.com) からモジュールをアドレス指定しようとすると、http 503 が生成されます。

どうしたの?

[更新] バックエンドを明示的に処理しています:

taksqueue.add(..., target='producer')

タスクキューのドキュメントには、モジュールでそれを行う方法は記載されていません。

【更新】プロデューサー.yaml

admin_console:
  pages:
  - name: Initialize
    url: /init
api_version: '1'
application: lpsng2
basic_scaling:
  max_instances: '1'
builtins:
- remote_api: 'on'
default_expiration: 8d
env_variables:
  TMP: C:\temp
handlers:
- login: admin
  mime_type: image/vnd.microsoft.icon,
  secure: optional
  static_files: static/favicon.ico
  upload: static/favicon.ico
  url: /favicon.ico
- login: admin
  mime_type: image/png
  secure: optional
  static_files: static/images/lpsng_icon_os_144.png
  upload: static/images/lpsng_icon_os_144.png
  url: /apple-touch-icon-precomposed.png
- login: admin
  mime_type: application/x-chrome-extension
  secure: optional
  static_files: static/lpsng.crx
  upload: static/lpsng.crx
  url: /static/lpsng.crx
- http_headers:
    Vary: Accept-Encoding
  login: admin
  mime_type: image/png
  secure: optional
  static_files: static/\1.png
  upload: static/(.*).png
  url: /static/(.*).png
- http_headers:
    Vary: Accept-Encoding
  login: admin
  mime_type: image/jpeg
  secure: optional
  static_files: static/\1.jpg
  upload: static/(.*).jpg
  url: /static/(.*).jpg
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_dir: static
  url: /static
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/lib/\2
  upload: source/lib/ace/lib/(.*)
  url: /js/(.*)/lib/ace/lib/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/css/\2
  upload: source/lib/ace/css/(.*)
  url: /js/(.*)/lib/ace/css/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/mode/\2
  upload: source/lib/ace/mode/(.*)
  url: /js/(.*)/lib/ace/mode/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/mode/json/\2
  upload: source/lib/ace/mode/json/(.*)
  url: /js/(.*)/lib/ace/mode/json/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/mode/python/\2
  upload: source/lib/ace/mode/python/(.*)
  url: /js/(.*)/lib/ace/mode/python/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/theme/\2
  upload: source/lib/ace/theme/(.*)
  url: /js/(.*)/lib/ace/theme/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/worker/\2
  upload: source/lib/ace/worker/(.*)
  url: /js/(.*)/lib/ace/worker/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/\2
  upload: source/lib/ace/(.*)
  url: /js/(.*)/lib/ace/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/lib/ace/\2/\3/\4
  upload: source/lib/ace/(.*)/(.*) /(.*)
  url: /js/(.*)/lib/ace/(.*)/(.*)/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: buildout/\2
  upload: buildout/(.*)
  url: /js/(.*)/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: buildcss/\1
  upload: buildcss/(.*)
  url: /css/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/\2/\3
  upload: dummy/dummy.txt
  url: /source/(.*)/(.*)/(.*)
- http_headers:
    Vary: Accept-Encoding
  login: admin
  secure: optional
  static_files: source/\2
  upload: dummy/dummy.txt
  url: /source/(.*)/(.*)
- script: main.app
  secure: optional
  url: .*
inbound_services:
- xmpp_message
instance_class: B8
libraries:
- name: webapp2
  version: 2.5.2
- name: markupsafe
  version: '0.15'
- name: jinja2
  version: '2.6'
- name: PIL
  version: 1.1.7
module: producer
runtime: python27
skip_files: (?:^(.*/)?app\.yaml)|(?:^(.*/)?app\.yml)|(?:^(.*/)?index\.yaml)|(?:^(.*/)?index\.yml)|(?:^(.*/)?#.*#)|(?:^(.*/)?.*~)|(?:^(.*/)?.*\.py[co])|(?:^(.*/)?.*/RCS/.*)|(?:^(.*/)?\..*)|(?:^dev/(.*))|(?:^build/(.*))|(?:(.*/source/.*))|(?:^source1/lib/([^\/]*)$)|(?:^dist/(.*)$)|(?:^data/blob/(.*))|(?:^data/log/(.*))|(?:^data/temp/(.*))|(?:^data/db/(.*))|(?:^conf/standalone[.](.*))|(?:^conf/enterprise[.](.*))|(?:^standalone/(.*))|(?:^Output/(.*))|(?:^Microsoft.VC90.CRT/(.*))|(?:^notUsed/(.*))|(?:^(.*)\.pxd)
threadsafe: true
version: '2'
4

2 に答える 2

1

1 つの方法:特定のタスク ハンドラーが特定のモジュールにルーティングされるように、ディスパッチ ファイルを設定できます。注:dispatch.yamlファイルに変更を加えた後、実行する必要があります

appcfg.py update_dispatch <proj_dir>
于 2013-08-05T00:45:57.797 に答える
0

本番環境で追加のモジュール (インスタンス) を開始するには

最終的に、ローカル マシンからコマンド ライン命令を発行する必要があることを発見しました。

$ appcfg.py update app.yaml worker.yaml

かなり小さな「GoogleAppEngineLauncher」がそれを行う場合、私はまだその方法を発見していません.

于 2014-10-27T23:17:42.657 に答える