Go Gin 框架 curl -I 返回 404 的问题
在使用 Go 的 Gin Web 框架的时候,发现一个有趣的问题,curl 一个 router 是正常的,但是加上 -I 参数就 404 了,就像下面这样
package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run() // listen and serve on 0.0.0.0:8080 }
正常的
curl http://127.0.0.1:8080/ping {"message":"pong"}
404的
curl -I http://127.0.0.1:8080/ping HTTP/1.1 404 Not Found Content-Type: text/plain Date: Wed, 31 Oct 2018 04:35:22 GMT Content-Length: 18
然后通过抓包发现,curl -I 的 http method 是 HEAD,但是我们只定义了GET,所以它就理所当然的 404 了
大部分时候这个样子,对我们也没什么影响,但是部分 slb 在对 http 服务做健康检查的时候,用的 HEAD 的 method,而且只认为 2xx 是正常的,所以,对于部分 router 我们可以用 Any 方法来注册所有 method 的路由,保证健康检查的正确性
package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.Any("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run() // listen and serve on 0.0.0.0:8080 }
结果
curl -I http://127.0.0.1:8080/ping HTTP/1.1 200 OK Content-Type: application/json; charset=utf-8 Date: Wed, 31 Oct 2018 05:13:20 GMT Content-Length: 18
这个 Any 方法十分简单实用
func (group *RouterGroup) Any(relativePath string, handlers ...HandlerFunc) IRoutes { group.handle("GET", relativePath, handlers) group.handle("POST", relativePath, handlers) group.handle("PUT", relativePath, handlers) group.handle("PATCH", relativePath, handlers) group.handle("HEAD", relativePath, handlers) group.handle("OPTIONS", relativePath, handlers) group.handle("DELETE", relativePath, handlers) group.handle("CONNECT", relativePath, handlers) group.handle("TRACE", relativePath, handlers) return group.returnObj() }
更多架构、PHP、GO相关踩坑实践技巧请关注我的公众号:PHP架构师
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Flutter瘦身大作战
摘要:作者:闲鱼技术-三莅 背景 闲鱼技术团队于2018年上半年率先引入了Flutter技术实现客户端开发,到目前为止成功改造并上线了复杂的商品详情和发布业务。随着改造业务的增多,安装包体积急剧上增。安装包体积决定了用户等待下载的时间和可能会耗费的流量,如何控制安装包体积,减小flutter产物的大小成为当务之急。 作者:闲鱼技术-三莅 背景 闲鱼技术团队于2018年上半年率先引入了Flutter技术实现客户端开发,到目前为止成功改造并上线了复杂的商品详情和发布业务。随着改造业务的增多,安装包体积急剧上增。安装包体积决定了用户等待下载的时间和可能会耗费的流量,如何控制安装包体积,减小flutter产物的大小成为当务之急。本文从闲鱼客户端项目实践角度给出了一些通用的包大小检测以及优化方案,希望为对Flutter感兴趣的团队提供参考。 闲鱼客户端采用的Flutter和Native混合开发的模式,下面我们以ios端为例分析项目中flutter产物的大小(ipa包瘦身需求更为急切)。 ios工程对Flutter有如下依赖: Flutter.framework :Flutter库和引擎 App....
- 下一篇
Netty NioEventLoop 启动过程源码分析
原文链接:https://wangwei.one/posts/netty-nioeventloop-analyse-for-startup.html 前面 ,我们分析了NioEventLoop的创建过程,接下来我们开始分析NioEventLoop的启动和执行逻辑。 Netty版本:4.1.30 启动 在之前分析 Channel绑定 的文章中,提到过下面这段代码,先前只讲了 channel.bind() 绑定逻辑,跳过了execute() 接口,现在我们以这个为例,开始分析NioEventLoop的execute()接口,主要逻辑如下: 添加任务队列 绑定当前线程到EventLoop上 调用EventLoop的run()方法 private static void doBind0( final ChannelFuture regFuture, final Channel channel, final SocketAddress localAddress, final ChannelPromise promise) { // 通过eventLoop来执行channel绑定的Task cha...
相关文章
文章评论
共有0条评论来说两句吧...