登录
首页 >  Golang >  Go问答

生产就绪的 Google Cloud Function 是什么样的?

来源:stackoverflow

时间:2024-04-07 09:18:29 499浏览 收藏

你在学习Golang相关的知识吗?本文《生产就绪的 Google Cloud Function 是什么样的?》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

我刚刚开始使用 google cloud functions 来完成整个无服务器的工作,所有示例基本上都是“helloworld”。

package function

import (
    "net/http"
)

func F(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("Hello, World!\n"))
}

生产就绪函数是什么样的?


解决方案


鉴于提供商会为您处理诸如扩展之类的事情,我要做的第一件事就是关注可观察性。你不知道你不知道什么。我喜欢添加自己的跟踪和结构化日志记录;记录到标准输出在很多方面都存在不足。

package function

import (
    "context"
    "fmt"
    "net/http"
    "os"
    "sync"

    "cloud.google.com/go/logging"
    "contrib.go.opencensus.io/exporter/stackdriver"
    "contrib.go.opencensus.io/exporter/stackdriver/propagation"
    "go.opencensus.io/trace"
    "google.golang.org/genproto/googleapis/api/monitoredres"
)

var (
    logger *logging.logger
    once   sync.once
)

// configfunc sets the global configuration; it's overridden in tests.
var configfunc = defaultconfigfunc

func f(w http.responsewriter, r *http.request) {
    once.do(func() {
        if err := configfunc(); err != nil {
           panic(err)
        }
    })

    defer logger.flush()

    ctx := r.context()
    var span *trace.span

    httpformat := &propagation.httpformat{}
    sc, ok := httpformat.spancontextfromrequest(r)
    if ok {
        ctx, span = trace.startspanwithremoteparent(ctx, "helloworld", sc,
            trace.withsampler(trace.alwayssample()),
            trace.withspankind(trace.spankindserver),
        )
        defer span.end()
    }

    logger.log(logging.entry{
        payload:  "handling new http request",
        severity: logging.info,
    })

    w.write([]byte("hello, world!\n"))
}

func defaultconfigfunc() error {
    var err error

    projectid := os.getenv("gcp_project")
    if projectid == "" {
            return fmt.errorf("gcp_project environment variable unset or missing")
    }

    functionname := os.getenv("function_name")
    if functionname == "" {
            return fmt.errorf("function_name environment variable unset or missing")
    }

    region := os.getenv("function_region")
    if region == "" {
        return fmt.errorf("function_region environment variable unset or missing")
    }

    stackdriverexporter, err := stackdriver.newexporter(stackdriver.options{projectid: projectid})
    if err != nil {
        return err
    }

    trace.registerexporter(stackdriverexporter)
    trace.applyconfig(trace.config{defaultsampler: trace.alwayssample()})

    client, err := logging.newclient(context.background(), projectid)
    if err != nil {
        return err
    }

    monitoredresource := monitoredres.monitoredresource{
        type: "cloud_function",
        labels: map[string]string{
            "function_name": functionname,
            "region":        region,
        },
    }

    commonresource := logging.commonresource(&monitoredresource)
    logger = client.logger(functionname, commonresource)

    return nil
}

此外,请确保您提供所有依赖项,您确实希望您的构建是可重现的。我这些天正在使用 go 1.11,以下内容对我有用:

$ mkdir helloworld
$ cd helloworld
$ vim function.go
$ echo "module github.com/kelseyhightower/helloworld" > go.mod
$ go mod vendor

本篇关于《生产就绪的 Google Cloud Function 是什么样的?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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