【发布时间】:2021-10-22 10:32:26
【问题描述】:
我正在使用教科书:“Go 编程语言”,其中展示了如何使用 Go 制作网络服务器。
按照他们给出的代码,我做了一个网络服务器:
package main
import (
"fmt"
"log"
"net/http"
"sync"
)
var mu sync.Mutex
var count int
func main() {
http.HandleFunc("/", handler)
http.HandleFunc("/count", counter)
log.Fatal(http.ListenAndServe("localhost:8080", nil))
}
func handler(w http.ResponseWriter, r *http.Request) {
mu.Lock()
count++
mu.Unlock()
fmt.Fprintf(w, "URL.Path = %q\n", r.URL.Path)
}
func counter(w http.ResponseWriter, r *http.Request) {
mu.Lock()
fmt.Fprintf(w, "Count %d\n", count)
mu.Unlock()
}
后来我想用 goroutine 测试我的知识,所以我编写了一个程序,将调用服务器端点:“/rest”1000 次。
然后我调用端点:“/count”,假设返回前一个端点被调用的次数。
send.go
package main
import (
"fmt"
"net/http"
"os"
"strconv"
"io/ioutil"
)
func main() {
times, _ := strconv.Atoi(os.Args[1])
for i := 0; i < times; i++ {
go call()
}
response, err := http.Get("http://localhost:8080/count")
if err != nil {
fmt.Println("ERROR ", err)
}
text, _ := ioutil.ReadAll(response.Body)
fmt.Println(string(text))
response.Body.Close()
}
func call() {
_, _= http.Get("http://localhost:8080/rest")
}
问题是这样的:/count 端点返回一个小于 1000 的数字。请告诉我我做错了什么,或者我是否误解了 sync.Mutex 或 http.HandleFunc() 的工作原理。
【问题讨论】:
-
谢谢,我尝试使用
sync.WaitGroup,一切正常。 -
@mkopriva 请创建一个答案,以便我接受
标签: go webserver mutex goroutine