-1

backend在 Google AppEngine 上使用推送队列和灵活环境时,执行使用服务创建的任务(要在服务上执行)时出现 403(禁止)错误default。任务已成功推送到队列,并在本地确认,但任务执行失败并显示日志:

INFO     2020-12-24 13:42:39,897 module.py:865] default: "POST /tasks/test-handler HTTP/1.1" 403 31
WARNING  2020-12-24 13:42:39,897 taskqueue_stub.py:2158] Task task2 failed to execute. The task has no remaining retries. Failing permanently after 1 retries and 0 seconds

这同样发生在本地和生产中。但是,如果使用 cron 作业创建任务,则执行工作正常。我正在使用dev_appserver.py具有以下.yaml定义的 Go 1.11:

# backend service
service: backend
runtime: go111
instance_class: F2

inbound_services:
- warmup
- default

handlers:
- url: /tasks/.*
  login: admin
  redirect_http_response_code: 301

# default app service
service: default
runtime: go111
instance_class: F2

inbound_services:
- warmup

handlers:
- url: /api/.*
  script: auto
  secure: always
  redirect_http_response_code: 301

初始 API 请求到达/api端点,然后使用以下命令成功推送队列消息:

t := taskqueue.NewPOSTTask(taskURL, url.Values{
    "testParam": {strconv.Itoa(testParam)},
})

if _, err := taskqueue.Add(ctx, t, "test-queue"); err != nil {
    return ErrPublishingTaskToQueue
}

我的queue.yaml定义(实际上我还有更多):

total_storage_limit: 120M
queue:
- name: test-queue
  rate: 1/s
  bucket_size: 100
  max_concurrent_requests: 10
  retry_parameters:
      task_retry_limit: 1

如果不是通过 cron 作业创建任务,为什么我会在任务执行中获得 403(禁止)状态?关于这个问题的文档和现有资源没有多大帮助:/

4

1 回答 1

1

设法使它工作。如果有人在 Google AppEngine 上的推送队列任务执行中遇到 403 响应,请确保您设置了正确的目标服务。target: backend在上面的示例中,我缺少queue.yaml

total_storage_limit: 120M
queue:
- name: test-queue
  rate: 1/s
  bucket_size: 100
  max_concurrent_requests: 10
  target: backend
  retry_parameters:
      task_retry_limit: 1

问题是任务是使用default服务创建的,默认情况下它们会命中default服务,但应该命中backend服务。不幸的是default,服务也部署了所需的端点,所以我得到了 403 而不是 404。

target有关该字段 的更多详细信息: https ://cloud.google.com/appengine/docs/standard/python/config/queueref#target

于 2021-01-05T08:34:06.450 回答