您的位置:首页 >如何使用 Golang 构建 RESTful API 并部署到 Docker?
发布于2025-06-14 阅读(0)
扫一扫,手机访问
在 Golang 中构建 RESTful API,部署到 Docker:创建 Golang 项目并定义数据结构。编写 API 处理程序,定义路由并启动 HTTP 服务器。创建 Dockerfile,构建 Docker 镜像并运行 Docker 容器。实战案例:使用 Postman 或 curl 测试 API。

如何在 Golang 中构建 RESTful API 并部署到 Docker
go mod init my-api
type User struct {
ID int `json:"id"`
Name string `json:"name"`
Email string `json:"email"`
Age int `json:"age"`
}package main
import (
"encoding/json"
"fmt"
"net/http"
"github.com/gorilla/mux"
)
func main() {
// 创建一个新的路由器
r := mux.NewRouter()
// 定义路由
r.HandleFunc("/users", getUsers).Methods("GET")
r.HandleFunc("/users/{id}", getUser).Methods("GET")
r.HandleFunc("/users", createUser).Methods("POST")
r.HandleFunc("/users/{id}", updateUser).Methods("PUT")
r.HandleFunc("/users/{id}", deleteUser).Methods("DELETE")
// 启动 HTTP 服务器
fmt.Println("Listening on port 8080")
http.ListenAndServe(":8080", r)
}
// 获取所有用户
func getUsers(w http.ResponseWriter, r *http.Request) {
// ...
}
// 获取单个用户
func getUser(w http.ResponseWriter, r *http.Request) {
// ...
}
// 创建用户
func createUser(w http.ResponseWriter, r *http.Request) {
// ...
}
// 更新用户
func updateUser(w http.ResponseWriter, r *http.Request) {
// ...
}
// 删除用户
func deleteUser(w http.ResponseWriter, r *http.Request) {
// ...
}FROM golang:1.18-alpine WORKDIR /usr/src/app COPY . ./ RUN go build -o my-api CMD ["my-api"]
docker build -t my-api-image .
docker run -p 8080:8080 my-api-image
实战案例:
可以将此 API 部署到 Docker 并使用 Postman 或 curl 进行测试。例如,创建一个名为 "test" 的用户:
curl -X POST http://localhost:8080/users -H "Content-Type: application/json" -d '{"name": "test", "email": "test@example.com", "age": 30}'
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9