golang 长短连接处理

前言

关于time_wait网上的介绍有很多,咱不啰嗦了,之前公司环境有台机器里有大量的time_wait,研究了下golang和http的基础,小结下。

http协议1.1后默认是长连接,如果一个client使用http1.1协议,但又不希望使用长链接,则需要在header中指明connection的值为close;如果server方也不想支持长链接,则在response中也需要明确说明connection的值为close。

Get / HTTP/1.1
Host: example.com
User-Agent: Go 1.1 package http
**Connection: close**
Accept-Encoding: gzip

HTTP/1.1 501 Not Implemented
Content-Type: text/html
Content-Length: 357
**Connection: close**
Date: Mon, 07 Mar 2016 13:15:56 GMT
Server: ECSF (iad/18D2)

golang里长短连接的一些处理

1)golang强制短连接

出了在请求的头里加上connection:close, 也可以设置request结构体Close成员变量为true,比如:

req, _ := http.NewRequest("Get", "http://example.com", nil)
req.Close = true

2)golang对长连接的要求

golang client不设置主动断连,还得注意下,想要保持长连接,得保证以下两个点

1. defer resp.Body.Close()  //别忘了close body,不然长连接保持不了
2. body, err := ioutil.ReadAll(resp.Body)//记得读完resp.body或者放置一个结束符号 io.Copy(ioutil.Discard,resp.Body)

3) 解决产生大量close_wait

解决方案网上挺多,待总结个比较合适的方案,再补上

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Golang中,数据库连接池是通过内部实现的连接池来实现的。连接的建立是惰性的,当你需要连接的时候,连接池会自动帮你创建。你不需要手动操作连接池,一切都由Golang来完成。 在Golang的标准库database/sql/sql.go中实现了数据库连接池。当我们使用sql.Open函数来创建连接时,实际上就是在使用连接池。例如,使用以下代码创建一个MySQL的连接池: db, err := sql.Open("mysql", "xxxx") 此外,我们还可以参考已经成熟并广泛使用的MySQL连接池库和Redis连接池库来了解连接池的实现方式。这些库通过实现连接池来提供更高效的数据库连接管理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [使用mysql数据库与go进行交互](https://blog.csdn.net/tianlongtc/article/details/80115240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Golang连接池的几种实现案例](https://blog.csdn.net/asd1126163471/article/details/127020095)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值