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

本文涉及的产品
Serverless 应用引擎 SAE,800核*时 1600GiB*时
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
函数计算FC,每月免费额度15元,12个月
简介: 【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框架更快更好地做其他事情。

目录
相关文章
|
2月前
|
监控 算法 Go
Golang深入浅出之-Go语言中的服务熔断、降级与限流策略
【5月更文挑战第4天】本文探讨了分布式系统中保障稳定性的重要策略:服务熔断、降级和限流。服务熔断通过快速失败和暂停故障服务调用来保护系统;服务降级在压力大时提供有限功能以保持整体可用性;限流控制访问频率,防止过载。文中列举了常见问题、解决方案,并提供了Go语言实现示例。合理应用这些策略能增强系统韧性和可用性。
171 0
|
28天前
|
Go
go创建web服务
go创建web服务
25 4
|
18天前
|
XML JSON Go
Swoole与Go系列教程之WebSocket服务的应用
在 WebSocket 协议出现之前,Web 应用为了能过获取到实时的数据都是通过不断轮询服务端的接口。轮询的效率、延时很低,并且很耗费资源。
1028 1
Swoole与Go系列教程之WebSocket服务的应用
|
1月前
|
存储 中间件 Go
在go语言服务中封装路由和示例
【6月更文挑战第23天】本文介绍golang后端按协议处理、中间件(一次性与每次请求执行)划分、以及服务架构Controller、Logic/Service、DAO/Repository和Routers划分。代码仓库在GitHub上提供。使用框架简化了交互和处理。后续章节深入探讨服务构建。
114 5
在go语言服务中封装路由和示例
|
17天前
|
网络协议 算法 Go
在go内置网络库中的路由和多路复用
【7月更文挑战第6天】本文介绍Go的`net/http`库提供基础的HTTP服务,`ListenAndServe`管理TCP连接,处理请求。处理程序默认使用`DefaultServeMux`。也可以选择多路复用模式ServeMux。它们的示例代码展示了自定义`ServeHTTP`结构体处理不同路由 。
32 2
|
17天前
|
网络协议 Go
Swoole与Go系列教程之TCP服务的应用
TCP(传输控制协议)的出现是为了解决计算机网络中的数据可靠传输和连接管理的问题。在早期的计算机网络中,特别是在分组交换和互联网的发展初期,网络是不可靠的,存在丢包、错误和延迟等问题。
965 0
Swoole与Go系列教程之TCP服务的应用
|
20天前
|
网络协议 程序员 应用服务中间件
Swoole与Go系列教程之HTTP服务的应用
PHP 曾是Web开发领域佼佼者,随着业务壮大,异步和高并发方面不足显现。Swoole 曾经尝试填补空白,但局限性也比较的明显。Go 语言的崛起,简洁语法和并发优势吸引大厂使用,吸引了大多数程序员的转型。
977 0
Swoole与Go系列教程之HTTP服务的应用
|
1月前
|
关系型数据库 Go 开发工具
|
1月前
|
缓存 Java Go
如何用Go语言构建高性能服务
【6月更文挑战第8天】Go语言凭借其并发能力和简洁语法,成为构建高性能服务的首选。本文关注使用Go语言的关键设计原则(简洁、并发、错误处理和资源管理)、性能优化技巧(减少内存分配、使用缓存、避免锁竞争、优化数据结构和利用并发模式)以及代码示例,展示如何构建HTTP服务器。通过遵循这些原则和技巧,可创建出稳定、高效的Go服务。
|
1月前
|
消息中间件 Kafka Go
go语言并发实战——日志收集系统(五) 基于go-ini包读取日志收集服务的配置文件
go语言并发实战——日志收集系统(五) 基于go-ini包读取日志收集服务的配置文件