mirror of https://github.com/v2ray/v2ray-core
Merge pull request #189 from darhwa/http-outbound
Fix the coarse-grained mutex in http outboundpull/2740/head
commit
3d855206c2
|
@ -210,9 +210,10 @@ func setUpHTTPTunnel(ctx context.Context, dest net.Destination, target string, u
|
||||||
}
|
}
|
||||||
|
|
||||||
cachedH2Mutex.Lock()
|
cachedH2Mutex.Lock()
|
||||||
defer cachedH2Mutex.Unlock()
|
cachedConn, cachedConnFound := cachedH2Conns[dest]
|
||||||
|
cachedH2Mutex.Unlock()
|
||||||
|
|
||||||
if cachedConn, found := cachedH2Conns[dest]; found {
|
if cachedConnFound {
|
||||||
rc, cc := cachedConn.rawConn, cachedConn.h2Conn
|
rc, cc := cachedConn.rawConn, cachedConn.h2Conn
|
||||||
if cc.CanTakeNewRequest() {
|
if cc.CanTakeNewRequest() {
|
||||||
proxyConn, err := connectHTTP2(rc, cc)
|
proxyConn, err := connectHTTP2(rc, cc)
|
||||||
|
@ -260,6 +261,7 @@ func setUpHTTPTunnel(ctx context.Context, dest net.Destination, target string, u
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cachedH2Mutex.Lock()
|
||||||
if cachedH2Conns == nil {
|
if cachedH2Conns == nil {
|
||||||
cachedH2Conns = make(map[net.Destination]h2Conn)
|
cachedH2Conns = make(map[net.Destination]h2Conn)
|
||||||
}
|
}
|
||||||
|
@ -268,6 +270,7 @@ func setUpHTTPTunnel(ctx context.Context, dest net.Destination, target string, u
|
||||||
rawConn: rawConn,
|
rawConn: rawConn,
|
||||||
h2Conn: h2clientConn,
|
h2Conn: h2clientConn,
|
||||||
}
|
}
|
||||||
|
cachedH2Mutex.Unlock()
|
||||||
|
|
||||||
return proxyConn, err
|
return proxyConn, err
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in New Issue