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 官方文档或社区论坛寻求帮助。祝您编码愉快!
HunyuanImage-3.0
HunyuanImage-3.0 统一多模态理解与生成,基于自回归框架,实现文本生成图像,性能媲美或超越领先闭源模型00- DDeepSeek-V3.2-ExpDeepSeek-V3.2-Exp是DeepSeek推出的实验性模型,基于V3.1-Terminus架构,创新引入DeepSeek Sparse Attention稀疏注意力机制,在保持模型输出质量的同时,大幅提升长文本场景下的训练与推理效率。该模型在MMLU-Pro、GPQA-Diamond等多领域公开基准测试中表现与V3.1-Terminus相当,支持HuggingFace、SGLang、vLLM等多种本地运行方式,开源内核设计便于研究,采用MIT许可证。【此简介由AI生成】Python00
GitCode-文心大模型-智源研究院AI应用开发大赛
GitCode&文心大模型&智源研究院强强联合,发起的AI应用开发大赛;总奖池8W,单人最高可得价值3W奖励。快来参加吧~0369Hunyuan3D-Part
腾讯混元3D-Part00ops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。C++095AI内容魔方
AI内容专区,汇集全球AI开源项目,集结模块、可组合的内容,致力于分享、交流。02Spark-Chemistry-X1-13B
科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00GOT-OCR-2.0-hf
阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00- HHowToCook程序员在家做饭方法指南。Programmer's guide about how to cook at home (Chinese only).Dockerfile09
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
项目优选









