Go의 net/http 응답에서 기본 소켓 얻기
Go의 net/http 패키지는 HTTP 서버 구축을 위한 편리한 프레임워크를 제공합니다. 그러나 응답 스트림의 기본 소켓에 액세스해야 하는 상황이 있을 수 있습니다. 이 문서에서는 소켓 연결을 검색하기 위한 다양한 접근 방식을 탐색하여 이에 대해 설명합니다.
Go 1.13 이전
Go 1.13 이전에는 기본 소켓을 얻으려면 더 정교한 기술이 필요했습니다. 다음은 두 가지 접근 방식입니다.
이벤트 기반 추적(TCP 연결만 해당):
TCP 포트를 통한 연결의 경우 net.Listener를 활용할 수 있습니다. 활성 연결 및 관련 소켓을 추적하는 ConnState 이벤트 핸들러. 이 정보는 나중에 검색할 수 있도록 글로벌 맵에 저장할 수 있습니다.
<code class="go">var conns = make(map[string]net.Conn) func ConnStateEvent(conn net.Conn, event http.ConnState) { if event == http.StateActive { conns[conn.RemoteAddr().String()] = conn } else if event == http.StateHijacked || event == http.StateClosed { delete(conns, conn.RemoteAddr().String()) } } func GetConn(r *http.Request) (net.Conn) { return conns[r.RemoteAddr] }</code>
리스너 재정의(Unix 소켓):
Unix 소켓에는 더 복잡한 각 연결에 대한 고유 식별자가 없기 때문에 접근 방식이 다릅니다. 한 가지 해결 방법은 net.Listener.Accept 메서드를 재정의하여 각 연결에 고유한 문자열을 할당하고 이를 소켓 정보 저장을 위한 키로 사용하는 것입니다.
<code class="go">func NewConnSaveListener(wrap net.Listener) (net.Listener) { return connSaveListener{wrap} } func (self connSaveListener) Accept() (net.Conn, error) { conn, err := self.Listener.Accept() ptrStr := fmt.Sprintf("%d", &conn) conns[ptrStr] = conn return remoteAddrPtrConn{conn, ptrStr}, err } func GetConn(r *http.Request) (net.Conn) { return conns[r.RemoteAddr] }</code>
Go 1.13 및 Beyond
Go 1.13이 출시되면서 더욱 간단한 솔루션이 제공됩니다.
컨텍스트 기반 스토리지:
Go 1.13부터 net.Conn은 HTTP 요청의 컨텍스트에 저장될 수 있습니다. 이는 소켓 연결에 액세스하는 깔끔하고 효율적인 방법을 제공합니다.
<code class="go">type contextKey struct { key string } var ConnContextKey = &contextKey{"http-conn"} func SaveConnInContext(ctx context.Context, c net.Conn) (context.Context) { return context.WithValue(ctx, ConnContextKey, c) } func GetConn(r *http.Request) (net.Conn) { return r.Context().Value(ConnContextKey).(net.Conn) }</code>
이러한 기술을 이해하면 net/http 응답 핸들러에서 기본 소켓을 효과적으로 검색하여 사용자 정의를 활성화할 수 있습니다. 운영 및 플랫폼별 기능을 제공합니다.
위 내용은 Go의 net/http 응답에서 기본 소켓에 어떻게 액세스합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!