Go语言通过net/http包实现HTTP服务器与路由处理,使用http.HandleFunc注册路由,http.ListenAndServe启动服务,默认基于DefaultServeMux;可通过自定义http.ServeMux实现更清晰的模块化路由管理。

在Go语言中搭建HTTP服务器并实现路由处理,核心在于利用其内置的
net/http
说实话,Go的
net/http
最基础的服务器搭建,你可能只需要几行代码:
package main
import (
"fmt"
"log"
"net/http"
)
func main() {
// 定义一个处理器函数,处理根路径的请求
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello, you've hit the root path!")
})
// 定义另一个处理器函数,处理/hello路径的请求
http.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) {
name := r.URL.Query().Get("name")
if name == "" {
name = "Guest"
}
fmt.Fprintf(w, "Hello, %s! Welcome to the Go server.", name)
})
// 启动HTTP服务器,监听8080端口
log.Println("Server starting on :8080...")
err := http.ListenAndServe(":8080", nil) // nil表示使用http.DefaultServeMux
if err != nil {
log.Fatalf("Server failed to start: %v", err)
}
}这里,
http.HandleFunc
http.HandlerFunc
http.ListenAndServe
nil
http.DefaultServeMux
立即学习“go语言免费学习笔记(深入)”;
但如果你想更明确地控制路由,或者需要构建更模块化的应用,你也可以自己创建一个
http.ServeMux
// ... (imports remain the same)
func main() {
mux := http.NewServeMux() // 创建一个新的多路复用器
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello from custom mux!")
})
mux.HandleFunc("/about", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "This is the about page.")
})
log.Println("Custom Mux Server starting on :8081...")
err := http.ListenAndServe(":8081", mux) // 将自定义的mux传入
if err != nil {
log.Fatalf("Custom Mux Server failed to start: %v", err)
}
}这样做的好处是,你可以拥有多个独立的路由集合,或者将路由逻辑封装在不同的模块中,代码结构会更清晰。
http.Handler
ServeHTTP(ResponseWriter, *Request)
http.HandlerFunc
Go语言在并发处理上真是独树一帜,这也是我个人觉得它非常适合构建高性能网络服务的原因之一。当你用
net/http
这意味着什么呢?简单来说,你写的每一个
http.HandlerFunc
但这种便利也带来了一些需要注意的地方。如果你的多个goroutine(也就是多个请求的处理)需要访问或修改共享的数据(比如一个全局计数器,或者一个缓存),那么你就必须小心了。如果不加保护,很容易出现竞态条件(race condition),导致数据不一致或者程序崩溃。这时候,
sync
sync.Mutex
sync/atomic
举个例子,如果你的处理器里有一个访问全局变量的逻辑:
// ...
import "sync"
var requestCounter int64
var mu sync.Mutex // 保护requestCounter
func counterHandler(w http.ResponseWriter, r *http.Request) {
mu.Lock() // 加锁
requestCounter++
currentCount := requestCounter
mu.Unlock() // 解锁
fmt.Fprintf(w, "Total requests processed: %d", currentCount)
}
// main函数中注册:http.HandleFunc("/count", counterHandler)
// ...通过
sync.Mutex
requestCounter
虽然Go内置的
net/http
/users/{id}http.DefaultServeMux
这时候,社区里涌现出了很多优秀的第三方路由库,它们极大地扩展了Go的路由能力。我个人用得比较多,也觉得比较
以上就是GolangHTTP服务器搭建 路由处理实现的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号