PHP小编香蕉今天为大家介绍的是“代理服务器上下文超时”问题。在网络通信中,代理服务器扮演着重要的角色,但有时会出现上下文超时的情况,导致请求无法正常完成。上下文超时是指在特定时间内,
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) {}} p>
当我将端点配置为 proxyAuthServerURL 并将 maxTimeout 配置为 AuthTimeout 时,为什么我的 proxyAuthServer 没有返回响应。有人可以解释一下吗
我猜测原因与超时设置有关。
我认为,假设服务器没有问题,从客户端的角度来看,超时/截止日期可能是由于两件事而发生的。
带有截止日期上下文的请求。 (https://www.php.cn/link/751f879c2408105e969d31617d31fbf5)
客户端超时 (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
}
以上就是代理服务器上下文超时的详细内容,更多请关注编程网其它相关文章!
--结束END--
本文标题: 代理服务器上下文超时
本文链接: https://lsjlt.com/news/564066.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0