登录
首页 >  Golang >  Go问答

部署Cloud Functions时出现错误:代码=3,消息=构建失败,错误ID:6191efcd

来源:stackoverflow

时间:2024-03-13 21:36:27 322浏览 收藏

大家好,我们又见面了啊~本文《部署Cloud Functions时出现错误:代码=3,消息=构建失败,错误ID:6191efcd》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

从今天早上开始,我收到以下错误,但我的代码没有任何变化(只是添加了 log.println()...即使返回到部署的先前版本也无法解决问题)

trigger.go(入口点)

// the function that runs with the cloud function itself
func handleusercreateevent(ctx context.context, e my_project.firestoreevent) error {

    log.println("-------------------- oldvalue --------------------")
    log.printf("name: %s\n", e.oldvalue.name)
    log.printf("createtime: %v\n", e.oldvalue.createtime)
    log.printf("fields: %v\n", e.oldvalue.fields)
    log.printf("updatetime: %v\n", e.oldvalue.updatetime)
    log.println("-------------------- newvalue --------------------")
    log.printf("name: %s\n", e.value.name)
    log.printf("createtime: %v\n", e.value.createtime)
    log.printf("fields: %v\n", e.value.fields)
    log.printf("updatetime: %v\n", e.value.updatetime)
    log.println("-------------------- jsonvalue -------------------")
    jsonb, _ := json.marshal(e.value)
    log.printf("json: %v\n", string(jsonb))
    log.println("---------------------- done ----------------------")

    // my code

    return nil

deploy.sh(还有一个可以正常工作的deploy.bat以及下面的sh脚本)

#!/usr/bin/env bash

# deployment automation

name="handleusercreateevent"
projectid="my_project"
collection="userscollection"

# must call go vendor as go modules are ignored
go mod vendor
yes y | gcloud functions deploy ${name} \
    --trigger-event providers/cloud.firestore/eventtypes/document.create \
    --trigger-resource "projects/${projectid}/databases/(default)/documents/${collection}/{pushid}" \
    --region europe-west1 \
    --runtime go113 \
    --allow-unauthenticated \
    --memory 128

由于这工作得很好,现在它不再工作了(如上所述,我刚刚添加了您在上面看到的代码的 jsonvalue 部分)

错误

macbook-pro-de-emixam23:my-project-elasticsearch-creater emixam23$ ./deploy.sh 
deploying function (may take a while - up to 2 minutes)...
....................................................failed.
error: (gcloud.functions.deploy) operationerror: code=3, message=build failed: # serverless_function_app/main
src/serverless_function_app/main/main.go:24:38: cannot use my_project_elasticsearch_creater.handleusercreateevent (type func(context.context, my_project_elasticsearch.firestoreevent) error) as type func(http.responsewriter, *http.request) in argument to funcframework.registerhttpfunction; error id: 6191efcd

有什么想法吗?我真的认为 gcloud 有一些问题......

更新 -> gcloud 真的坏了

我刚刚重新部署了一个空函数,只有一个简单的结构作为没有依赖项的包(将模块设为空)

type firestoreevent struct {
    oldvalue   interface{} `json:"oldvalue"`
    value      interface{} `json:"value"`
    updatemask struct {
        fieldpaths []string `json:"fieldpaths"`
    } `json:"updatemask"`
}

还是同样的问题

C:\Workspace\go\src\gitlab-group\my-project-elasticsearch-creater>gcloud --version
Google Cloud SDK 298.0.0
app-engine-go
app-engine-python 1.9.91
bq 2.0.58
cloud-datastore-emulator 2.1.0
core 2020.06.19
gsutil 4.51

解决方案


我在同一天结束时尝试了完全相同的方法,并且成功了......

我认为这是与 Google Cloud Platform 相关的问题,不知道为什么我们无法在几个小时内部署它。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《部署Cloud Functions时出现错误:代码=3,消息=构建失败,错误ID:6191efcd》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>