登录
首页 >  Golang >  Go问答

使用Gorilla Mux在GCP云函数中实现路由控制

来源:stackoverflow

时间:2024-03-19 19:51:29 422浏览 收藏

在 GCP 云函数中,用户可以通过指定入口点来控制路由。然而,对于基于 HTTP 触发的单一用途函数,GCP 云函数更适合执行特定任务,而不是像 HTTP 服务器那样提供全面路由功能。如果需要构建微服务架构,可以创建多个由 HTTP 触发的不同函数,每个函数分配一个独立的 HTTP 地址,并通过应用程序调用它们。对于需要分布式微服务的场景,建议考虑使用 Google Appengine,它允许部署服务器并使用特定端点共享 URL。

问题内容

我是 gogcp 的新手,所以我可能无法提供所有详细信息。但会尝试分享我所拥有的。

我使用 docker 设置了一个小型微服务。 docker-compose 文件运行我的 main 方法,该方法通过 gorrillamux 注册 http 处理程序...它按预期工作。这是示例代码

func main() {
    r := gorrilamux.newrouter()
    r.handlefunc("/stores/orders/{orderid}/status", handler).methods("get")
    http.handle("/", r)
    fmt.printf("%+v", http.listenandserve(":8080", nil))
}

func handler(w http.responsewriter, r *http.request) {
    fmt.println("------ in handler!!!")
}

使用此代码,我可以在执行 docker-compose -up 后调用我的服务。我感到困惑的是,我将如何使用这个 gorrilla mux 在 goocle 云功能中路由我的呼叫?

根据我的理解,对于gcp cf,我会告诉什么方法是入口点,即

gcloud functions deploy service-name  --entry-point handler

这个 handler 会在收到每个请求时调用,它不会是 listenandservce。那么我如何使用 gorillamux 来做到这一点?

我最终想要做的是从传入请求中提取路径变量。一种方法是使用字符串操作并仅从 request 对象获取路径变量。但这可能容易出错。所以我想是否可以使用 gorilla mux 来处理这些事情。

任何想法


解决方案


Google Cloud Functions 用于基于 HTTP 或其他 GCP 服务器到服务器触发器等触发器执行单一用途函数。你的 go 服务看起来更像是一个 HTTP 服务器,而不是一个单一的函数。

如果您想使用 Cloud Functions 建立微服务架构,您要做的就是创建一堆主要由 HTTP 触发的不同函数(每个函数都会自动分配不同的 HTTP 地址),然后从您的应用程序调用它们无需任何外部 HTTP 路由器。

如果您想要一个分布式微服务(每个服务共享相同的 URL,但 URL 中具有不同的端点),您需要查看 Appengine,您可以在其中部署服务器。您可以使用 this 教程开始使用 Google Appengine

以上就是《使用Gorilla Mux在GCP云函数中实现路由控制》的详细内容,更多关于的资料请关注golang学习网公众号!

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