我正在编写一个简单的代理,将HTTP请求转发给一个或多个后端服务器.现在我仍然只使用一个后端服务器,但性能不好,我确信我做错了什么.可能与我如何将HTTP请求发送到另一台服务器有关:如果我对该呼叫发表评论,send()那么服务器会快速超速,产生超过14 krps.虽然send()性能调用下降到不到1 krps,但随着时间的推移下降甚至更低.这是在MacBook Pro上.
代码基于简单的代码示例; 我已client根据文档中的建议创建并重用它.测试是通过Apache完成的ab:
$ ab -n 10000 -c 10 -k "http://127.0.0.1:8080/test"
Run Code Online (Sandbox Code Playgroud)
在端口55455上运行的后端服务器在实验之间不会改变; 可以使用Apache或nginx.我的自定义Web服务器直接测量时产生的速度超过7 krps,没有代理:
$ ab -n 10000 -c 10 -k "http://127.0.0.1:55455/test"
Run Code Online (Sandbox Code Playgroud)
我希望代理版本的行为与非代理版本一样好,并且随着时间的推移保持性能.
完整的示例代码如下.
package main
import (
"fmt"
"log"
"net/http"
)
func main() {
tr := &http.Transport{
DisableCompression: true,
DisableKeepAlives: false,
}
client := &http.Client{Transport: tr}
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
send(r, client)
fmt.Fprintf(w, "OK")
})
log.Fatal(http.ListenAndServe(":8080", nil))
}
func send(r *http.Request, client *http.Client) int {
req, err := http.NewRequest("GET", "http://localhost:55455" + r.URL.Path, nil)
if err != nil {
log.Fatal(err)
return 0
}
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
return 0
}
if resp == nil {
return 0
}
return 1
}
Run Code Online (Sandbox Code Playgroud)
最终,代码应该将请求发送到多个服务器并处理它们的答案,并返回带有结果的int.但是我只是在打电话这一步.
我做错了什么?
正如评论所暗示的,你应该返回(和处理)类型错误而不是整数,并重申,不要使用AB.对我来说最重要的是
MaxIdleConnsPerHost你的Transport.这表示即使当前没有任何关系,仍将保持多少个连接(保持活动状态)....
resp, err := client.Do(req)
if err != nil {
return err
}
responseBody, err := ioutil.ReadAll(resp.Body)
if err != nil {
return err
}
defer resp.Body.Close()
...
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4999 次 |
| 最近记录: |