Golang-使用Thrift请求后得到HttpStatus413

栏目: Go · 发布时间: 7年前

内容简介:Thrift请求后得到HttpStatus413是什么鬼?以下会为你一一解答。1.HttpStatus 413是什么意思?HTTP Status 413 (请求实体过大)

Thrift请求后得到HttpStatus413是什么鬼?以下会为你一一解答。

Let's Go!

1.解决方案

  • 自己继承后重新实现(推荐)
  • 修改thrfit包中SetHeader/Flush方法,增加重置header逻辑
  • 每次都重新创建Thrift连接

2.环境

  • Golang version:1.5
  • Linux version:Linux version 2.6.32-279.el6.x86_64 (gcc version 4.4.6 20120305 (Red Hat 4.4.6-4) (GCC) )
  • Os version:CentOS release 6.3 (Final) 2.6.32-279.el6.x86_64
  • Cpu :12
  • Mem :8G
  • 网络协议:Thrift

3.场景

  • 使用Sync.pool管理调用Thrift的goroutine,减少创建及销毁goroutine开销,c为调用client
c := pool.Get()
    defer pool.Put(c)
    以下为调用逻辑....

4.问题现象

错误信息

  • Client端报Http Status 413
  • Server端无报错信息

5.问题原因

1.HttpStatus 413是什么意思?

HTTP Status 413 (请求实体过大)

注意:这里请求实体过大的意思是包括header和body(一开始定位时只定位了body,就进坑了- -)

针对该问题主要为header过大

2.RPC时会设置header,但对于存在于pool中的goroutine,是Addheader,请看以下代码,

// Set the HTTP Header for this specific Thrift Transport
// It is important that you first assert the TTransport as a THttpClient type
// like so:
//
// httpTrans := trans.(THttpClient)
// httpTrans.SetHeader("User-Agent","Thrift Client 1.0")
func (p *THttpClient) SetHeader(key string, value string) {
    p.header.Add(key, value)
}

这就是导致出现413的原因


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

复盘+:把经验转化为能力(第2版)

复盘+:把经验转化为能力(第2版)

邱昭良 / 机械工业出版社 / 39.00

随着环境日趋多变、不确定、复杂、模糊,无论是个人还是组织,都需要更快更有效地进行创新应变、提升能力。复盘作为一种从经验中学习的结构化方法,满足了快速学习的需求,也是有效进行知识萃取与共享的机制。在第1版基础上,《复盘+:把经验转化为能力》(第2版)做了六方面修订: ·提炼复盘的关键词,让大家更精准地理解复盘的精髓; ·基于实际操作经验,梳理、明确了复盘的"底层逻辑"; ·明确了复......一起来看看 《复盘+:把经验转化为能力(第2版)》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器