卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章35526本站已运行397

代理服务器上下文超时

代理服务器上下文超时

php小编香蕉今天为大家介绍的是“代理服务器上下文超时”问题。在网络通信中,代理服务器扮演着重要的角色,但有时会出现上下文超时的情况,导致请求无法正常完成。上下文超时是指在特定时间内,代理服务器无法获得请求的上下文信息,从而导致连接中断。本文将详细解析代理服务器上下文超时的原因和解决方法,帮助读者更好地理解和应对这个问题。无需担心,我们会用通俗易懂的语言,尽量简明扼要地为大家解答。

问题内容

我正在尝试测试 HttpServer 代码。我在代码中模拟了我的代理调用 这是我的服务器代码:

func HttpServer(t *testing.T,version string,test ReqRes, basePath string, timeout int,transport metrics.HttpInstrumenter, corsConfig middleware.CorsConfig) (*http.Response,[]byte, bool){
    proxyAuthServer := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
        w.WriteHeader(test.proxyAuthStatusCode)
        _, err := w.Write([]byte(test.proxyAuthResp))
        if err != nil {
            return
        }
    }))

    defer proxyAuthServer.Close()

    configs :=config.Config{
        Outbounds: struct {
            APIAuthentication struct {
                AuthPath    string `yaml:"authPath"`
                AuthTimeout int    `yaml:"authTimeout"`
            } `yaml:"apiauthentication"`
            
        },
    }


    var mockProxy proxy.Proxies
    newproxy:=proxy.NewProxies(zap.NewNop(),proxyInstrumenter,proxyTransport)
    mockProxy,_=newproxy.Make(configs,proxyAuthServer.URL,"")

    proxyAuthServer.URL=proxyAuthServer.URL+configs.Outbounds.APIAuthentication.AuthPath


    service:=base.NewService(proxy.Proxies{ApiAuthenticationService:mockProxy.ApiAuthenticationService,OfferPrefixDataService:mockProxy.OfferPrefixDataService},true) 
    service=base.NewLoggingMiddleware(zap.NewNop())(service)
    service = base.NewInstrumentingService(instrumenter)(service)


    //Generating req
    resp,_:=http.DefaultClient.Do(req)
    body,_:=io.ReadAll(resp.Body)
    return resp,body,false

}

这是调用代理并给出错误的行。s 实现了我的 AuthProxy:

endpointResp, err := s.ValidateEndpoint(ctx, req)

每当我的代码进行代理调用时,proxyAuthServer 就会在我的调试器中返回如下错误:

endpointResp:接口 {} nil

错误(*net/url.Error): *{Op: "Get", URL: "http://127.0.0.1:58807/auth", Err: error(context.deadlineExceededError) {}}

当我将端点配置为 proxyAuthServerURL 并将 maxTimeout 配置为 AuthTimeout 时,为什么我的 proxyAuthServer 没有返回响应。有人可以解释一下吗

解决方法

我猜测原因与超时设置有关。

我认为,假设服务器没有问题,从客户端的角度来看,超时/截止日期可能是由于两件事而发生的。

  1. 带有截止日期上下文的请求。 (https://www.php.cn/link/751f879c2408105e969d31617d31fbf5)

  2. 客户端超时 (https://www.php.cn/link/2976a6e4f9f094965adb965397c96dcf)

您的问题与截止日期无关。所以我猜大约是2。

我们可以通过这段代码轻松测试它。

package main

import (
    "fmt"
    "net/http"
    "net/http/httptest"
    "time"
)

func main() {
    server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
        fmt.Fprint(w, "This is only for test")
    }))

    req, _ := http.NewRequest("GET", server.URL, nil)

    client := http.Client{Timeout: time.Nanosecond}
    _, err := client.Do(req)
    if err != nil {
        fmt.Println(err)
        return
    }

    return
}

卓越飞翔博客
上一篇: 如何为任何通道类型定义类型约束
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏