requestHandler := func(ctx *fasthttp.RequestCtx) {
time.Sleep(time.Second*time.Duration(10))
fmt.Fprintf(ctx, "Hello, world! Requested path is %q", ctx.Path())
}
s := &fasthttp.Server{
Handler: requestHandler
}
if err := s.ListenAndServe("127.0.0.1:82"); err != nil {
log.Fatalf("error in ListenAndServe: %s", err)
}
多个请求,它花费时间像X * 10s。 fasthttp是单一过程吗?
两天后...... 我很抱歉这个问题,我不太清楚地描述我的问题。我的问题是由浏览器引起的,浏览器通过同步请求相同的URL,并且它误导了我,它让认为fasthttp web服务器通过同步来处理请求。 / p>
答案 0 :(得分:2)
我认为而不是 fasthttp是单个进程吗?,你是否在询问fasthttp是否同时处理客户端请求?
我非常确定任何服务器(包括 fasthttp )包都会同时处理客户端请求。您应该编写测试/基准测试,而不是通过几个浏览器手动访问服务器。以下是此类测试代码的示例:
package main_test
import (
"io/ioutil"
"net/http"
"sync"
"testing"
"time"
)
func doRequest(uri string) error {
resp, err := http.Get(uri)
if err != nil {
return err
}
defer resp.Body.Close()
_, err = ioutil.ReadAll(resp.Body)
if err != nil {
return err
}
return nil
}
func TestGet(t *testing.T) {
N := 1000
wg := sync.WaitGroup{}
wg.Add(N)
start := time.Now()
for i := 0; i < N; i++ {
go func() {
if err := doRequest("http://127.0.0.1:82"); err != nil {
t.Error(err)
}
wg.Done()
}()
}
wg.Wait()
t.Logf("Total duration for %d concurrent request(s) is %v", N, time.Since(start))
}
结果(在我的电脑中)是
fasthttp_test.go:42:1000个并发请求的总持续时间为10.6066411s
您可以看到问题的答案是不,它会同时处理请求。
更新:
如果请求的URL相同,您的浏览器可以按顺序执行请求。见Multiple Ajax requests for same URL。这解释了为什么响应时间为X*10s
。
答案 1 :(得分:0)
我很抱歉这个问题,我的问题描述得不好。我的问题是由浏览器引起的,浏览器通过同步请求相同的网址,并且它误导我,它让我认为fasthttp web服务器通过以下方式处理请求同步。