Laravel Sail 快速上手指南
一、项目介绍
Laravel Sail 是一个基于 Docker 的开发环境,用于本地开发 Laravel 应用程序。它提供了预配置的容器来运行 MySQL、PostgreSQL、Redis、Memcached 和 Mailhog 等服务,使得开发者无需担心本地数据库和其他配置问题。
使用 Sail,您可以在所有操作系统(包括 Windows)中以一致的方式进行测试,这避免了由于开发环境差异带来的潜在问题。此外,Sail 提供了一个方便的命令行接口来进行常见的开发任务,如运行单元测试或清除缓存。
二、项目快速启动
安装 Docker
首先,确保您的机器上安装了 Docker Desktop。如果您还没有安装 Docker Desktop,请访问 https://www.docker.com/products/docker-desktop 并下载适用于您的操作系统的版本。
安装 Sail
接下来,在项目根目录下运行以下命令:
composer require laravel/sail --dev
此命令将把 sail 这个包添加到您的项目依赖里,并将其作为开发工具使用。之后,您就可以在项目文件夹中通过 ./vendor/bin/sail 命令来调用 Sail。
配置 Sail
编辑 .env 文件中的数据库配置,以便 Sail 可以正确地连接到它们:
DB_CONNECTION=sail
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=mydatabase
DB_USERNAME=root
DB_PASSWORD=root
现在,您可以准备使用 Sail 来运行 Laravel 应用了。
启动 Sail
输入以下命令来启动 Docker 容器:
./vendor/bin/sail up -d
该命令会在后台运行所有必需的服务容器。稍等片刻待所有服务完全加载。
访问 Laravel 应用
您可以通过访问 http://localhost 来查看您的 Laravel 应用。
单元测试
要运行应用程序的所有单元测试,只需执行下面的命令:
./vendor/bin/sail test
这将打开 Docker 中的 PHP 测试环境并运行所有测试。
三、应用案例和最佳实践
典型场景:使用 Sail 调整数据库配置
假设您正在切换到 PostgreSQL 数据库,那么您只需修改 .env 文件中的数据库配置选项即可。Sail 将自动适应新设置并更新其相关配置项。
例如:
DB_CONNECTION=sail
DB_HOST=pgsql
DB_DRIVER=pgsql
...
这样,您不需要重新写入任何代码就能轻松适配新的数据库类型。
最佳实践:利用 Sail 执行常规维护工作
通常,除了部署之外,您还需要对 Laravel 应用进行一些日常维护工作,比如清理缓存、生成数据库迁移或重建索引。您可借助 Sail 的 CLI 命令快速完成这些操作。
例如,以下命令可用于刷新全局缓存:
./vendor/bin/sail artisan cache:clear
或者创建一个新的数据库迁移:
./vendor/bin/sail artisan make:migration add_columns_to_posts_table
使用 Sail 不仅可以简化您的 Laravel 开发体验,还能帮助您更加高效且一致地完成日常工作。
四、典型生态项目
为了进一步了解如何在实际项目中运用 Laravel Sail,可以参考以下几个具有代表性的示例:
-
RealWorld 示例:这个示例展示了如何使用 Laravel Sail 构建一个遵循《RealWorld》规范的应用程序。它包含了身份验证系统、API 文档生成、以及前后端分离架构等内容。
- 相关仓库地址:
https://git.example.com/briannesbitt/realworld-example-app
- 相关仓库地址:
-
多数据库支持:演示如何在单一 Laravel 项目内管理多个数据库实例。无论是为不同的环境分别设定数据库,还是在一个环境下处理多个数据源,这个示例都提供了一种可行方案。
- 相关仓库地址:
https://git.example.com/laravel/database-scaffold
- 相关仓库地址:
以上两个示例不仅介绍了如何使用 Laravel Sail,还覆盖了一系列软件工程的最佳实践,例如代码结构、单元测试、以及持续集成配置。它们可以为您提供一份从零开始构建 Laravel 项目的全面指导,同时加深对 Sail 功能的理解。
总之,Laravel Sail 为 Laravel 开发者带来了许多便利,极大地简化了本地开发流程。无论您是在构建简单的 API,还是复杂的微服务平台,Sail 都是值得尝试的解决方案。希望本指南能帮助您更好地掌握这一工具!
如果您遇到任何问题或有任何疑问,请查阅 Laravel 官方文档或社区论坛寻求帮助。祝您编码愉快!
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00