如果您希望在不使用goroutine的情况下按顺序执行代码,可以将代理请求放在本地请求之后处理。这样,在判断条件满足时直接处理本地请求,否则先进行代理转发,然后再处理本地请求的逻辑。以下是相应修改后的代码示例:
// 创建HTTP处理函数来同时处理本地请求和代理请求
handlerFunc := func(w http.ResponseWriter, r *http.Request) {
// 判断是否启用HA且host可达
if haEnabled && !isHostReachable(haHost) {
// 处理本地请求的逻辑
// ...
} else {
proxyURL := "http://proxy-server:port" // 代理服务器地址
proxyReq, err := http.NewRequest(r.Method, proxyURL, r.Body)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
proxyReq.Header = r.Header.Clone()
resp, err := proxyClient.Do(proxyReq)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
defer resp.Body.Close()
// 将代理响应返回给本地客户端
for key, values := range resp.Header {
for _, value := range values {
w.Header().Add(key, value)
}
}
w.WriteHeader(resp.StatusCode)
io.Copy(w, resp.Body)
// 处理本地请求的逻辑
// ...
}
}
// 创建HTTP服务器并启动监听
serverAddr := ":8080" // 本地服务器地址和端口号
server := &http.Server{
Addr: serverAddr,
Handler: http.HandlerFunc(handlerFunc),
}
// 启动HTTP服务器
c.lc.Infof("cfgSrv start to listening %s...", serverAddr)
err := server.ListenAndServe()
if err != nil {
c.lc.Errorf("ListenAndServe failed. ERROR: %v", err)
}
在上述代码中,当判断条件满足时,直接处理本地请求的逻辑。否则,在进行代理转发后再处理本地请求的逻辑。这样就可以按照顺序执行而不使用goroutine并保证逻辑正确性。请根据您的实际需求修改相关变量和逻辑部分。
内容由零声教学AI助手提供,问题来源于学员提问