使用go的内置的基础路由服务

本文涉及的产品
应用实时监控服务-用户体验监控,每月100OCU免费额度
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 【6月更文挑战第19天】本文探索Go的HTTP服务:基础路由与多路复用。基础服务示例绑定到`:http`,返回非零错误。多路复用允许按URL模式匹配请求,长路径优先,注册时考虑主机名。错误路径重定向至根。代码示例见:https://github.com/hahamx/examples/tree/main/tcps/2_with_http_handler

简介

天下难事,必始于易。 慎始如终,则不败事。 --老子

本文介绍两个基本的路由绑定方式,基础路由服务和多路复用路由服务。它们都使用net/http包提供HTTP服务,ListenAndServe管理TCP连接。服务通过goroutines处理请求,启用HTTP/2需TLS配置为h2;。

1 基础http路由服务

内建的包 net/http 为http服务提供了很多功能,包括建立tcp连接和 sockets连接管理,这些都被ListenAndserve函数所包括。

然后调用与处理程序一起服务以处理传入连接的请求。接受的连接被配置为启用 TCP,并保持活动。

处理程序通常为 nil,在这种情况下使用 DefaultServeMux。 这在上一节有讲到。

ListenAndServe 总是返回一个非零错误

其主体服务程序形式为:

    type zooms struct{}

    func (h zooms) ServeHTTP(res http.ResponseWriter, req *http.Request) {
         ...
    }

    func httpServer() { 
        http.ListenAndServe(httpPort, zk) 
    }

如果Serve的地址 为空,则使用“:http”。 ListenAndServe 总是返回一个非零错误。关机或关闭后,返回的错误是 ErrServerClosed。

Serve 接受 Listener 上的传入连接,每个新的服务都将创建一个 goroutine。
goroutines 服务 读取请求和 然后调用 srv.Handler 来回复他们。

仅当监听器返回 *tls.Conn 时才启用 HTTP/2 支持连接,并且它们在 TLS 中的Config.NextProtos配置为“h2”.

当服务失败时总是返回一个非零错误并关闭 listener. Shutdown 或 Close 后,返回的错误是 ErrServerClosed。

访问猫头鹰

    http://127.0.0.1:3010/owls
        miao,miao...

访问大象

    http://127.0.0.1:3010/elephants
        ang,ang...

访问老虎

    http://127.0.0.1:3010/tiger
        aoo,aoo...

2 多路复用 http路由服务

http请求多路复用器,它为每一个进入的请求,在注册列表进行有针对的匹配使用模式匹配最接近的URL 路由,模式也调用处理器的处理程序。

模式使用最终的,根路径,如 /favicon.ico 或者 根路径子路由树 如 /images/ 注意最后跟了路径分割符长路径优先于短路径匹配。

如果长路径不存在,比如/ele/food/ 不存在, 将缩减直到根路径 / 。请看后面的例子。

如果两个路径都存在,比如 /ele/, /ele/food 此后的程序将使用长路由 /ele/food

需要注意的是,如果/ele/的某个子路由, 比如 /ele/foo 不存在,那么其子路由/ele/foo的任何调用都将 匹配到/ele/。

如果 路由 /ele 没有 路径分割符/, 那么/ele/foo 将直接匹配到 根路由 /

如果路由定义了 最终分隔符 /ele/ 但是调用是没有指定, 只是使用 /ele调用那么,

系统将返回一个 301重定向的提示,如果使用浏览器将被自动导向/ele/, 即 301,200 至少两次调用,

因为在编写路由 /ele/时, ServeMux 将/ele 和 /ele/ 都写入了注册器中。

    curl http://127.0.0.1:3020/ele
    <a href="/ele/">Moved Permanently</a>.

该注册模式可选以一个主机名开始,因此限制只能在该主机域名进行匹配。 主机特定匹配优先于 一般的模式匹配,

因此一个处理函数可能注册两个模式,而不需要接入 http://www.google.com/

    /codesearch
    codesearch.google.com 

ServeMux 将负责验证URL请求路径和主机的域名,剥离端口号并重定向包含的任何请求,或重复的元素如 //,直到获得干净的url

  http://127.0.0.1:3020\/ele\/
  http://127.0.0.1:3020//ele//

    scheme http
    host 127.0.0.1:3020
    filename //ele/

比如在本示例中,端口3020服务没有 大象 elephants,该路由算法将 匹配到 根路径 /

    curl http://127.0.0.1:3020/
    welcome Big Zoom!

错误调用路径将返回到根路由

    curl  http://127.0.0.1:3020/ele/food/
    welcome Big Zoom!

正确调用

    curl  http://127.0.0.1:3020/ele/food
    corn,apple,rice,grass...

其主体服务形式为:

    type zooms struct{}

    func (h zooms) ServeHTTP(res http.ResponseWriter, req *http.Request) {
        ...
    }

    //创建http多路复用服务
    func muxHttpServer() {
        var manager zooms 
        router := http.NewServeMux()
        router.Handle("/", manager)

        http.ListenAndServe(muxPort, router) 
    }

其中 Handle 注册给定模式的处理程序。如果模式的处理程序已经存在,则抛出恐慌错误。

访问老虎

    http://127.0.0.1:3020/tiger
        aoo,aoo,aoo,aoo,...

访问猫头鹰

    http://127.0.0.1:3020/owl
        wu,wu,wu,wu,...

访问大象

    http://127.0.0.1:3020/ele/
        ang,ang,ang,ang,...  

喂食大象

    http://127.0.0.1:3020/ele/food
        corn,apple,rice,grass...

3 小结

感谢一起旅程的你。
本节完整代码:

    https://github.com/hahamx/examples/blob/main/tcps/2_with_http_handler/http_service.go

下一节我们继续旅程,使用http框架更快更好地做其他事情。

目录
相关文章
|
4月前
|
缓存 弹性计算 API
用 Go 快速开发一个 RESTful API 服务
用 Go 快速开发一个 RESTful API 服务
|
18天前
|
Go UED
Go Web服务中如何优雅平滑重启?
在生产环境中,服务升级时如何确保不中断当前请求并应用新代码是一个挑战。本文介绍了如何使用 Go 语言的 `endless` 包实现服务的优雅重启,确保在不停止服务的情况下完成无缝升级。通过示例代码和测试步骤,详细展示了 `endless` 包的工作原理和实际应用。
36 3
|
19天前
|
JSON Go UED
Go Web服务中如何优雅关机?
在构建 Web 服务时,优雅关机是一个关键的技术点,它确保服务关闭时所有正在处理的请求都能顺利完成。本文通过一个简单的 Go 语言示例,展示了如何使用 Gin 框架实现优雅关机。通过捕获系统信号和使用 `http.Server` 的 `Shutdown` 方法,我们可以在服务关闭前等待所有请求处理完毕,从而提升用户体验,避免数据丢失或不一致。
17 1
|
6月前
|
Go
go创建web服务
go创建web服务
|
3月前
|
Go API 开发者
深入探讨:使用Go语言构建高性能RESTful API服务
在本文中,我们将探索Go语言在构建高效、可靠的RESTful API服务中的独特优势。通过实际案例分析,我们将展示Go如何通过其并发模型、简洁的语法和内置的http包,成为现代后端服务开发的有力工具。
|
4月前
|
安全 Go Docker
Go服务Docker Pod不断重启排查和解决
该文章分享了Go服务在Docker Pod中不断重启的问题排查过程和解决方案,识别出并发写map导致fatal error的问题,并提供了使用sync.Map或concurrent-map库作为并发安全的替代方案。
46 4
|
4月前
|
监控 Go 微服务
使用 ServiceWeaver 构建 go 服务
使用 ServiceWeaver 构建 go 服务
|
4月前
|
安全 小程序 Go
如何更干净地退出Go服务
如何更干净地退出Go服务
|
4月前
|
运维 监控 容灾
[go 面试] 实现服务高可用的策略和实践
[go 面试] 实现服务高可用的策略和实践
|
5月前
|
XML JSON Go
Swoole与Go系列教程之WebSocket服务的应用
在 WebSocket 协议出现之前,Web 应用为了能过获取到实时的数据都是通过不断轮询服务端的接口。轮询的效率、延时很低,并且很耗费资源。
1059 2
Swoole与Go系列教程之WebSocket服务的应用