0

0

laravel怎么使用GitHub Actions实现自动化测试和部署_laravel GitHub Actions自动化测试与部署方法

冰火之心

冰火之心

发布时间:2025-10-28 14:54:02

|

543人浏览过

|

来源于php中文网

原创

通过配置GitHub Actions可实现Laravel项目的自动化测试与部署。首先在项目根目录的.github/workflows/中创建ci-cd.yml文件,定义工作流触发条件为推送或拉取请求至main分支。工作流包含test和deploy两个主要任务:test任务在Ubuntu环境中运行,启动MySQL服务并设置PHP版本为8.1,通过缓存加速Composer依赖安装,复制.env.example文件并生成应用密钥,执行数据库迁移与种子填充,并运行单元测试,所有数据库配置使用环境变量注入;deploy任务依赖test成功执行,且仅在推送到main分支时触发,通过ssh-action使用SSH密钥连接远程服务器,执行git pull、composer安装、配置缓存及Nginx重载等命令完成部署。为保障安全,SSH主机、用户名和私钥均通过GitHub Secrets管理,避免敏感信息泄露。建议启用缓存提升效率,结合phpstan等工具进行静态分析,并区分不同环境的部署策略,也可集成Laravel Forge或Envoy实现更复杂流程。最终实现从代码提交到生产部署的全流程自动化,提高开发效率与系统稳定性。

laravel怎么使用github actions实现自动化测试和部署_laravel github actions自动化测试与部署方法

在现代 Laravel 项目开发中,使用 GitHub Actions 实现自动化测试和部署是一种高效、可靠的方式。通过配置工作流(Workflow),可以在代码推送到仓库时自动运行测试、检查代码质量,并将应用部署到生产或预发布环境。

配置 GitHub Actions 工作流文件

GitHub Actions 的工作流由 YAML 文件定义,存放在项目根目录的 .github/workflows/ 目录中。创建一个名为 ci-cd.yml 的文件,用于定义自动化流程。

以下是一个典型的 Laravel 项目 CI/CD 配置示例:

name: Laravel CI/CD

on: push: branches: [ main ] pull_request: branches: [ main ]

jobs: test: runs-on: ubuntu-latest

services:
  mysql:
    image: mysql:8.0
    env:
      MYSQL_ROOT_PASSWORD: rootpassword
      MYSQL_DATABASE: homestead
    ports:
      - 3306:3306
    options: --health-start-period=10s --health-interval=1s --health-timeout=5s --health-retries=30

steps:
  - name: Checkout code
    uses: actions/checkout@v4

  - name: Setup PHP
    uses: shivammathur/setup-php@v2
    with:
      php-version: '8.1'
      extensions: mbstring, dom, pdo, mysql, curl, openssl
      tools: composer:v2

  - name: Cache Composer dependencies
    uses: actions/cache@v3
    with:
      path: vendor
      key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
      restore-keys: ${{ runner.os }}-php-

  - name: Install dependencies
    run: composer install -q --no-ansi --no-interaction --no-scripts --no-progress

  - name: Copy .env
    run: cp .env.example .env

  - name: Generate application key
    run: php artisan key:generate

  - name: Run migrations
    run: php artisan migrate:fresh --seed
    env:
      DB_CONNECTION: mysql
      DB_HOST: 127.0.0.1
      DB_PORT: 3306
      DB_DATABASE: homestead
      DB_USERNAME: root
      DB_PASSWORD: rootpassword

  - name: Run tests
    run: php artisan test
    env:
      DB_CONNECTION: mysql
      DB_HOST: 127.0.0.1
      DB_PORT: 3306
      DB_DATABASE: homestead
      DB_USERNAME: root
      DB_PASSWORD: rootpassword

添加部署任务到服务器

测试通过后,可以配置部署步骤,将代码自动推送到生产或测试服务器。常用方式是通过 SSH 执行远程命令。

jobs 下新增 deploy 任务:

硅基智能
硅基智能

基于Web3.0的元宇宙,去中心化的互联网,高质量、沉浸式元宇宙直播平台,用数字化重新定义直播

下载
  deploy:
    needs: test
    runs-on: ubuntu-latest
    if: github.ref == 'refs/heads/main'
steps:
  - name: Deploy to Server
    uses: appleboy/ssh-action@v0.1.10
    with:
      host: ${{ secrets.SSH_HOST }}
      username: ${{ secrets.SSH_USER }}
      key: ${{ secrets.SSH_PRIVATE_KEY }}
      script: |
        cd /var/www/html/my-laravel-app
        git pull origin main
        composer install --optimize-autoloader --no-dev
        php artisan config:cache
        php artisan route:cache
        php artisan view:cache
        systemctl reload nginx

注意:需要在 GitHub 仓库的 Settings > Secrets and variables > Actions 中设置以下密钥:

  • SSH_HOST:目标服务器 IP 或域名
  • SSH_USER:SSH 登录用户名(如 ubuntu、root)
  • SSH_PRIVATE_KEY:私钥内容(建议使用无密码密钥并限制权限)

优化与安全建议

为了提升自动化流程的效率和安全性,可参考以下建议:

  • 使用缓存加快依赖安装速度,避免每次重复下载 Composer 包
  • 在部署前运行代码静态分析,例如使用 phpstanpint
  • 为不同环境(如 staging、production)设置不同的分支策略和部署条件
  • 避免在脚本中硬编码敏感信息,全部使用 GitHub Secrets 管理
  • 考虑使用 Laravel Forge 或 Envoy 结合 GitHub Actions 实现更复杂的部署逻辑

基本上就这些。通过合理配置 GitHub Actions,Laravel 项目可以实现从提交代码到测试再到部署的全流程自动化,显著提升开发效率和系统稳定性。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2677

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1658

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1515

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1419

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 801人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号