Github Actions和Docker实现自动部署

简介

在现代软件开发中,CI/CD(持续集成/持续部署)已经成为标准实践。通过Github Actions和Docker的结合,我们可以实现代码提交后的自动构建、测试和部署,大大提高开发效率。

Github Actions简介

Github Actions是Github提供的自动化工作流工具,可以自动执行软件开发中的各种任务。每当有代码推送或PR时,都可以触发预定义的工作流程。

实战配置

1. 创建工作流配置文件

在项目根目录创建.github/workflows/deploy.yml文件:

yaml:.github/workflows/deploy.yml 复制代码
name: Deploy to Production

on:
  push:
    branches:
      - main

jobs:
  build-and-deploy:
    runs-on: ubuntu-latest
    
    steps:
      - name: Checkout code
        uses: actions/checkout@v2

      - name: Login to Docker Hub
        uses: docker/login-action@v1
        with:
          username: ${{ secrets.DOCKER_USERNAME }}
          password: ${{ secrets.DOCKER_PASSWORD }}

      - name: Build and push Docker image
        uses: docker/build-push-action@v2
        with:
          context: .
          push: true
          tags: your-username/your-app:latest

2. 创建Dockerfile

在项目根目录创建Dockerfile

dockerfile:Dockerfile 复制代码
FROM node:16-alpine

WORKDIR /app

COPY package*.json ./
RUN npm install

COPY . .

EXPOSE 3000
CMD ["npm", "start"]

3. 配置密钥

在Github仓库的Settings -> Secrets中添加以下密钥:

  • DOCKER_USERNAME: Docker Hub用户名
  • DOCKER_PASSWORD: Docker Hub密码

工作流程说明

  1. 当代码推送到main分支时,工作流自动触发
  2. 检出代码到运行环境
  3. 登录到Docker Hub
  4. 构建Docker镜像并推送到Docker Hub
  5. (可选)部署到服务器

服务器自动部署

可以在服务器上创建一个简单的部署脚本:

bash:deploy.sh 复制代码
#!/bin/bash

# 拉取最新镜像
docker pull your-username/your-app:latest

# 停止并删除旧容器
docker stop your-app || true
docker rm your-app || true

# 启动新容器
docker run -d \
  --name your-app \
  -p 3000:3000 \
  your-username/your-app:latest

优势

  1. 自动化: 减少人工操作,提高效率
  2. 一致性: 确保开发、测试和生产环境的一致性
  3. 可追溯: 每次部署都有完整的日志记录
  4. 快速回滚: 出现问题时可以快速回退到之前的版本

注意事项

  1. 确保.gitignore正确配置,避免敏感信息泄露
  2. 定期清理旧的Docker镜像,避免占用过多存储空间
  3. 建议在workflow中添加测试步骤
  4. 考虑使用Docker多阶段构建优化镜像大小

总结

通过Github Actions和Docker的结合,我们可以轻松实现代码的自动化构建和部署。这不仅提高了开发效率,也保证了部署的一致性和可靠性。

相关推荐
程序员天天困10 小时前
Loop Engineering 实战:/goal 命令让 AI 自己写完整项目
github
徐小夕10 小时前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
小爷毛毛_卓寿杰11 小时前
我把 397B 的「Agentic 大脑」塞进了 Xinference,一键部署 Nex-N2
人工智能·架构·github
小爷毛毛_卓寿杰13 小时前
我把一个 3B 模型塞进了 Xinference,然后它干掉了 DeepSeek V3.2
人工智能·开源·github
凌奕13 小时前
别用文档约束你的 Agent:聊聊 Agent 开发流程的思想
llm·github·agent
HelloGitHub18 小时前
《HelloGitHub》第 123 期
开源·github
逛逛GitHub1 天前
这个 GitHub 有意思啊,Claude Code + Obsidian = 知识库王炸。
github
ZaferLiu2 天前
当Agent需要动手干活:Tool还是MCP?
github
鹏毓网络科技4 天前
Cursor Rules 文件配置实战:3 个隐藏参数让我每月少写 40% 样板代码
前端·github
Patrick_Wilson4 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js