简介
在现代软件开发中,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密码
工作流程说明
- 当代码推送到main分支时,工作流自动触发
- 检出代码到运行环境
- 登录到Docker Hub
- 构建Docker镜像并推送到Docker Hub
- (可选)部署到服务器
服务器自动部署
可以在服务器上创建一个简单的部署脚本:
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
优势
- 自动化: 减少人工操作,提高效率
- 一致性: 确保开发、测试和生产环境的一致性
- 可追溯: 每次部署都有完整的日志记录
- 快速回滚: 出现问题时可以快速回退到之前的版本
注意事项
- 确保
.gitignore
正确配置,避免敏感信息泄露 - 定期清理旧的Docker镜像,避免占用过多存储空间
- 建议在workflow中添加测试步骤
- 考虑使用Docker多阶段构建优化镜像大小
总结
通过Github Actions和Docker的结合,我们可以轻松实现代码的自动化构建和部署。这不仅提高了开发效率,也保证了部署的一致性和可靠性。