使用 Airdrop 加速你的 CI 构建

发布日期:作者:

Speed up your CI builds with Airdrop image

我正在努力尽可能少地使用 NodeJS。为什么?因为这会减慢人们在 Chipper CI 上的构建速度!

幸运的是,Airdrop 存在。

Laravel Airdrop 是一种存储已构建静态资产的工具。当您执行 CI 运行时,Airdrop 会检查您的静态资产是否已更改。

如果资产没有更改,Airdrop 会从存储中下载它们并放置在正确的位置 - 允许您跳过构建资产。

如果它们已更改,则照常使用 Node 构建静态资产。

这对节省 CI 和部署时间非常有用。

以下是使用 Airdrop 的方法。

安装

安装 Airdrop 很容易

composer require hammerstone/airdrop
 
# Add config/airdrop.php to your project
php artisan airdrop:install

配置 Airdrop

在 Airdrop 中只需要配置几件事 - 其中许多可以保留默认值。

触发器

您可以告诉 Airdrop 何时决定重新构建静态资产。

触发器特定于 **环境** (APP_ENV) - 每个环境都有自己的文件集。这称为配置触发器。

另一个触发器是 FileTrigger。这会跟踪配置的文件,并在文件更改时重建资产。

FileTrigger 将检查

  1. resources 中的文件 (CSS、JS 等)
  2. 如果 Webpack/Vite 配置文件发生变化

我还添加了 NPM 生成的 package-lock.json 文件。

<?php
 
use Hammerstone\Airdrop\Drivers\FilesystemDriver;
use Hammerstone\Airdrop\Drivers\GithubActionsDriver;
use Hammerstone\Airdrop\Triggers\ConfigTrigger;
use Hammerstone\Airdrop\Triggers\FileTrigger;
 
return [
'driver' => env('AIRDROP_DRIVER', 'default'),
'drivers' => [
'default' => [...],
'github' => [...],
],
'triggers' => [
ConfigTrigger::class => [
'env' => env('APP_ENV')
],
FileTrigger::class => [
'include' => [
resource_path(), // default
base_path('webpack.mix.js'), // mix default
base_path('vite.config.js'), // vite default
base_path('package-lock.json'), // my addition here
],
],
],
'outputs' => [...],
];

驱动程序

您可以决定 Airdrop 将静态资产存储在何处。通常你只需要使用 FilesystemDriver,并使用 Laravel 的 Storage 机制来告诉 Airdrop 将文件放在哪里。

disk 设置与使用的 Laravel “磁盘”存储有关。建议使用一些远程存储,例如 s3

GitHub Actions 驱动程序允许您将文件保存到 GH Actions 缓存中,这非常方便!

return [
// The driver you wish to use to stash and restore your files.
'driver' => env('AIRDROP_DRIVER', 'default'),
 
'drivers' => [
'default' => [
// The class responsible for implementing the stash and restore
// logic. Must extend BaseDriver.
'class' => FilesystemDriver::class,
 
// The disk on which to store the built files.
'disk' => env('AIRDROP_REMOTE_DISK', 's3'),
 
// The folder (if any) where you'd like your stashed assets to reside.
'remote_directory' => env('AIRDROP_REMOTE_DIR', 'airdrop'),
 
// A writeable directory on the machine that builds the assets.
// Used to build up the ZIP file before stashing it.
'local_tmp_directory' => env('AIRDROP_LOCAL_TMP_DIR', storage_path('framework')),
 
// The skip file is an empty file that will be created to
// indicate that asset building can be skipped.
'skip_file' => env('AIRDROP_SKIP_FILE', base_path('.airdrop_skip')),
],
],
// ...
];

输出

输出是 Airdrop 将为您存储和检索的文件。您通过触发器“监视”的文件不一定需要与您让 Airdrop 为您保存/存储的文件相同!

Airdrop 的默认值相当不错,当然您可以根据需要对其进行配置。

return [
// ...
'outputs' => [
/*
* Files or folders that should be included.
*/
'include' => [
// Mix/Webpack
public_path('mix-manifest.json'),
public_path('css'),
public_path('js'),
 
// Vite
public_path('build/manifest.json'),
public_path('build/assets'),
],
 
// ...
],
];

注意:使用 Airdrop 时,您可能不希望将静态资产提交到您的存储库。为了避免这种情况,并完成 Airdrop 的配置,请将以下内容添加到您的 .gitignore 文件中

/.airdrop_skip
 
# Mix/Webpack
public/css/*
public/js/**
 
# Vite
public/build/*

集成 Airdrop

当您构建应用程序 Airdrop 在 CI 中,或在部署脚本中(这非常适合 Forge 快速部署!),您可以运行以下命令

# Download files, only if needed
php artisan airdrop:download
 
# Airdrop creates .airdrop_skip if
# it downloaded files
if [ ! -f ".airdrop_skip" ]; then
npm ci --no-audit
npm run dev
fi
 
# Upload the files if needed
php artisan airdrop:upload
Chris Fidao photo

CloudCastsServers for Hackers 教授编码和服务器。 Chipper CI 的联合创始人。

归档于
Cube

Laravel 新闻通讯

加入 40,000 多名其他开发者,绝不错过新技巧、教程等更多内容。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和对本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

无妥协

Joel 和 Aaron,两位来自无妥协播客的资深开发者,现在可以为您的 Laravel 项目聘用。 ⬧ 固定价格为 7,500 美元/月。 ⬧ 没有冗长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

无妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?立即,自动化的 Laravel 升级和代码现代化,让您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

只需 2,500 美元/月,即可使用拥有 4-6 年经验的资深 Laravel 开发人员为您的项目增光添彩。获得 160 小时的专用专业知识和 15 天的无风险试用。立即安排电话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - Laravel 开发的理想之选,拥有十多年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源包,将现代无头电子商务功能的力量带到 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 招聘板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一款 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、精美结账、管理面板、用户仪表板、身份验证、即用型组件、统计、博客、文档等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您无缝 Laravel 升级的合作伙伴,降低成本,加速创新,帮助企业取得成功

Rector
MongoDB logo

MongoDB

通过强大的 MongoDB 和 Laravel 集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。探索 MongoDB 的灵活、现代数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一款简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

将 Swagger UI 添加到您的 Laravel 应用程序

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel 提示构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包为您的 Laravel 应用程序添加评论

阅读文章