I built a http.Client
for HTTP2 connection, what do I need to do to release the client and resource used?
Making request calls to an API means making an HTTP(s) request to a web server according to the API's precise documentation. The client is the host (e.g., the browser) that makes the request to a web server for a specific service or data through the HTTP protocol in the form of a URL and receives a response.
Http clients are thread safe according to the docs (https://golang.org/src/net/http/client.go): Clients are safe for concurrent use by multiple goroutines.
http.Client
does not require any special way to free "used" resources. When it becomes unreachable, memory used by it will be reclaimed by the garbage collector.
http.Client
does not store connection or state information. The documentation even states that http.Client
should be reused:
The Client's Transport typically has internal state (cached TCP connections), so Clients should be reused instead of created as needed. Clients are safe for concurrent use by multiple goroutines.
If you build your own client using (e.g. embedding) http.Client
and you allocate resources that must be released explicitly, provide your own Close()
method on it and document that anyone who uses your own implementation must call Close()
if it is not needed anymore.
Note:
What you might confuse it with is that if you use an http.Client
to do HTTP operations (like Client.Do()
, Client.Get()
, Client.Post()
etc.), they return a value of *http.Response
, and that response does hold a connection, state and other resources, which does need to be freed, typically via Response.Body.Close()
. Quoting from the package doc of http
:
The client must close the response body when finished with it:
resp, err := http.Get("http://example.com/") if err != nil { // handle error } defer resp.Body.Close() body, err := ioutil.ReadAll(resp.Body) // ...
It is also documented at Client.Get()
:
When err is nil, resp always contains a non-nil resp.Body. Caller should close resp.Body when done reading from it.
The CloseIdleConnections()
method was added in Go 1.12.
https://golang.org/pkg/net/http/#Client.CloseIdleConnections
CloseIdleConnections closes any connections on its Transport which were previously connected from previous requests but are now sitting idle in a "keep-alive" state. It does not interrupt any connections currently in use.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With