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 官方文档或社区论坛寻求帮助。祝您编码愉快!
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
请把这个活动推给顶尖程序员😎本次活动专为懂行的顶尖程序员量身打造,聚焦AtomGit首发开源模型的实际应用与深度测评,拒绝大众化浅层体验,邀请具备扎实技术功底、开源经验或模型测评能力的顶尖开发者,深度参与模型体验、性能测评,通过发布技术帖子、提交测评报告、上传实践项目成果等形式,挖掘模型核心价值,共建AtomGit开源模型生态,彰显顶尖程序员的技术洞察力与实践能力。00
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
MiniMax-M2.5MiniMax-M2.5开源模型,经数十万复杂环境强化训练,在代码生成、工具调用、办公自动化等经济价值任务中表现卓越。SWE-Bench Verified得分80.2%,Multi-SWE-Bench达51.3%,BrowseComp获76.3%。推理速度比M2.1快37%,与Claude Opus 4.6相当,每小时仅需0.3-1美元,成本仅为同类模型1/10-1/20,为智能应用开发提供高效经济选择。【此简介由AI生成】Python00
Qwen3.5Qwen3.5 昇腾 vLLM 部署教程。Qwen3.5 是 Qwen 系列最新的旗舰多模态模型,采用 MoE(混合专家)架构,在保持强大模型能力的同时显著降低了推理成本。00- RRing-2.5-1TRing-2.5-1T:全球首个基于混合线性注意力架构的开源万亿参数思考模型。Python00