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 官方文档或社区论坛寻求帮助。祝您编码愉快!
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00- DDeepSeek-OCRDeepSeek-OCR是一款以大语言模型为核心的开源工具,从LLM视角出发,探索视觉文本压缩的极限。Python00
MiniCPM-V-4_5MiniCPM-V 4.5 是 MiniCPM-V 系列中最新且功能最强的模型。该模型基于 Qwen3-8B 和 SigLIP2-400M 构建,总参数量为 80 亿。与之前的 MiniCPM-V 和 MiniCPM-o 模型相比,它在性能上有显著提升,并引入了新的实用功能Python00
HunyuanWorld-Mirror混元3D世界重建模型,支持多模态先验注入和多任务统一输出Python00
MiniMax-M2MiniMax-M2是MiniMaxAI开源的高效MoE模型,2300亿总参数中仅激活100亿,却在编码和智能体任务上表现卓越。它支持多文件编辑、终端操作和复杂工具链调用Jinja00
Spark-Scilit-X1-13B科大讯飞Spark Scilit-X1-13B基于最新一代科大讯飞基础模型,并针对源自科学文献的多项核心任务进行了训练。作为一款专为学术研究场景打造的大型语言模型,它在论文辅助阅读、学术翻译、英语润色和评论生成等方面均表现出色,旨在为研究人员、教师和学生提供高效、精准的智能辅助。Python00
GOT-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).Dockerfile014
Spark-Chemistry-X1-13B科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00