答案:使用Golang和Docker Compose可高效管理多容器微服务应用。首先编写Golang Web服务,连接PostgreSQL并提供/health和/users接口;通过Dockerfile构建轻量镜像,利用docker-compose.yml定义app和db服务,实现容器编排;最后通过docker-compose up启动应用,curl验证服务正常。常见优化包括添加.dockerignore、健康检查、静态编译及安全凭证管理,适用于本地开发与轻量部署。

使用Golang和Docker Compose管理多容器应用是一种常见的开发部署方式,尤其适用于微服务架构。下面通过一个简单的示例展示如何用Golang编写Web服务,并通过Docker Compose管理多个容器(如Go应用和PostgreSQL数据库)。
项目结构
先建立如下目录结构:
go-docker-compose-example/ ├── main.go ├── go.mod ├── Dockerfile └── docker-compose.yml
Golang Web服务代码
创建main.go,实现一个连接PostgreSQL的简单HTTP服务:
package mainimport ( "database/sql" "log" "net/http" "os"
_ "github.com/lib/pq")
立即学习“go语言免费学习笔记(深入)”;
func main() { db, err := sql.Open("postgres", os.Getenv("DATABASE_URL")) if err != nil { log.Fatal(err) } if err := db.Ping(); err != nil { log.Fatal("无法连接数据库:", err) }
http.HandleFunc("/health", func(w http.ResponseWriter, r *http.Request) { w.Write([]byte("OK")) }) http.HandleFunc("/users", func(w http.ResponseWriter, r *http.Request) { var count int db.QueryRow("SELECT COUNT(*) FROM users").Scan(&count) w.Write([]byte("用户总数: " + fmt.Sprint(count))) }) log.Println("服务器启动在 :8080") log.Fatal(http.ListenAndServe(":8080", nil))}
运行前需执行:go mod init example,并添加依赖:
go get github.com/lib/pq
Dockerfile 构建镜像
创建Dockerfile用于构建Go应用镜像:
FROM golang:1.21-alpine AS builder WORKDIR /app COPY . . RUN go build -o main .FROM alpine:latest RUN apk --no-cache add ca-certificates WORKDIR /root/ COPY --from=builder /app/main . CMD ["./main"]
Docker Compose 配置多容器
创建docker-compose.yml,定义Go应用和PostgreSQL容器:
version: '3.8'services: app: build: . ports:
- "8080:8080" environment: DATABASE_URL: postgres://user:password@db:5432/mydb?sslmode=disable depends_on:
- db
db: image: postgres:15 environment: POSTGRES_USER: user POSTGRES_PASSWORD: password POSTGRES_DB: mydb ports:
- "5432:5432" volumes:
- postgres_data:/var/lib/postgresql/data
volumes: postgres_data:
该配置包含两个服务:
运行与验证
在项目根目录执行:
docker-compose up -d
查看日志:
docker-compose logs app
访问健康接口:
curl http://localhost:8080/health
返回OK表示服务正常。
常见优化点
- 使用
.dockerignore排除不必要的文件 - 在生产环境中使用更安全的数据库凭证管理方式
- 添加健康检查(healthcheck)字段确保依赖正确启动
- 为Go应用启用静态编译以减小镜像体积
基本上就这些。这套组合适合本地开发和轻量级部署,结构清晰,易于扩展。










