diff --git a/DEPLOY.md b/DEPLOY.md index e3a58b6..3d7b26c 100644 --- a/DEPLOY.md +++ b/DEPLOY.md @@ -19,16 +19,17 @@ chmod +x deploy.sh ```bash # 构建 -docker build -t your-registry/chatroom:latest . +docker build -t zhengdushi/chatroom:latest . # 推送(示例:Docker Hub / 阿里云 ACR) -docker push your-registry/chatroom:latest +docker push zhengdushi/chatroom:latest ``` ### 2. 服务器拉取并部署 ```bash -./deploy.sh your-registry/chatroom:latest +cd ~/chatroom +docker compose pull app && docker compose up -d ``` ## 三、自动更新部署 diff --git a/Dockerfile b/Dockerfile index fdbef40..891fcbc 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,46 +2,22 @@ FROM golang:1.24-alpine AS builder WORKDIR /app +RUN apk add --no-cache gcc musl-dev # 仅当需要 CGO 时才保留(你的代码可能不需要,但保留无害) -# 安装编译依赖(仅用于 CGO,但你已禁用 CGO,其实可省略) -# 如果确实不需要 CGO(如纯 Go 代码),可删除下一行以加速构建 -RUN apk add --no-cache gcc musl-dev - -# 复制模块文件并下载依赖 COPY go.mod go.sum ./ RUN go mod download -# 复制源码 COPY . . - -# 编译静态二进制(CGO_ENABLED=0 确保无动态链接) RUN CGO_ENABLED=0 GOOS=linux go build -trimpath -ldflags="-s -w" -o server ./cmd/server/main.go - # 第二阶段:运行 FROM alpine:latest - -# 安全加固:创建非 root 用户 -RUN addgroup -g 1001 -S app && \ - adduser -u 1001 -S app -G app - +RUN addgroup -g 1001 -S app && adduser -u 1001 -S app -G app WORKDIR /app - -# 从构建阶段复制二进制和静态资源 COPY --from=builder /app/server . COPY --from=builder /app/web ./web - -# 更改文件所有者(安全最佳实践) RUN chown -R app:app /app - -# 切换到非 root 用户 USER app - -# 暴露端口 EXPOSE 2779 - -# 设置默认端口(可通过 docker run -e PORT=... 覆盖) ENV PORT=2779 - -# 启动应用 CMD ["./server"] \ No newline at end of file diff --git a/cmd/server/main.go b/cmd/server/main.go index a27fa49..5da5a37 100644 --- a/cmd/server/main.go +++ b/cmd/server/main.go @@ -14,7 +14,7 @@ func main() { rabbitmqURL := os.Getenv("RABBITMQ_URL") if rabbitmqURL == "" { rabbitmqURL = "amqp://guest:guest@localhost:5672/" - } + } rmq, err := rabbitmq.NewClient(rabbitmqURL) if err != nil { log.Fatalf("RabbitMQ 连接失败: %v", err) diff --git a/deploy.sh b/deploy.sh new file mode 100644 index 0000000..8cf3c3d --- /dev/null +++ b/deploy.sh @@ -0,0 +1,36 @@ +#!/bin/bash +# ChatRoom 自动部署脚本 +# 用法: ./deploy.sh [镜像地址] +# 示例: ./deploy.sh # 本地构建部署 +# ./deploy.sh registry.cn-hangzhou.aliyuncs.com/xxx/chatroom:latest # 从镜像仓库拉取部署 + +set -e + +COMPOSE_FILE="docker-compose.yml" +PORT=2779 + +echo "==========================================" +echo " ChatRoom 部署脚本 - 端口 $PORT" +echo "==========================================" + +if [ -n "$1" ]; then + # 从远程仓库拉取镜像并部署 + export CHATROOM_IMAGE="$1" + echo ">>> 拉取镜像: $CHATROOM_IMAGE" + docker compose -f "$COMPOSE_FILE" pull app + echo ">>> 启动容器..." + docker compose -f "$COMPOSE_FILE" up -d --no-build +else + # 本地构建并部署 + echo ">>> 构建并启动..." + docker compose -f "$COMPOSE_FILE" up -d --build +fi + +echo "" +echo ">>> 部署完成!" +echo " 服务地址: http://localhost:$PORT" +echo " WebSocket: ws://localhost:$PORT/ws" +echo "" +echo ">>> 查看日志: docker compose logs -f app" +echo ">>> 停止服务: docker compose down" +echo "==========================================" diff --git a/docker-compose.yml b/docker-compose.yml index eb3ad3f..ee5e598 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,28 +1,42 @@ +version: '3.8' + services: app: - build: . - # 生产环境可设置 CHATROOM_IMAGE 从镜像仓库拉取,如: registry.cn-hangzhou.aliyuncs.com/xxx/chatroom:latest - image: ${CHATROOM_IMAGE:-chatroom:latest} + image: zhengdushi/chatroom:latest # 直接使用你推送的镜像 container_name: chatroom-app - labels: - - "com.centurylinklabs.watchtower.enable=true" # Watchtower 监控此容器 ports: - "2779:2779" environment: - - RABBITMQ_URL=amqp://guest:guest@rabbitmq:5672/ - PORT=2779 + - RABBITMQ_HOST=rabbitmq + - RABBITMQ_USER=admin + - RABBITMQ_PASS=1218Zhengyaqi # ← 请务必修改为你的密码! + - RABBITMQ_URL=amqp://admin:1218Zhengyaqi@rabbitmq:5672/ + depends_on: - rabbitmq: - condition: service_healthy + - rabbitmq + restart: unless-stopped + networks: + - chatroom-net rabbitmq: - image: rabbitmq:3-management + image: rabbitmq:3-management-alpine container_name: chatroom-rabbitmq ports: - "5672:5672" - "15672:15672" - healthcheck: - test: ["CMD", "rabbitmq-diagnostics", "-q", "check_running"] - interval: 5s - timeout: 15s - retries: 5 + environment: + RABBITMQ_DEFAULT_USER: admin + RABBITMQ_DEFAULT_PASS: 1218Zhengyaqi # ← 必须和上面一致! + volumes: + - rabbitmq_data:/var/lib/rabbitmq + restart: unless-stopped + networks: + - chatroom-net + +networks: + chatroom-net: + driver: bridge + +volumes: + rabbitmq_data: \ No newline at end of file