如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南

在 macos 上配置并运行 laravel 项目,核心在于使用 laravel valet 搭建轻量高效的本地开发环境。1. 安装 xcode command line tools;2. 安装 homebrew;3. 使用 homebrew 安装 php;4. 安装 composer;5. 安装 mysql 或其他数据库;6. 安装 laravel valet;7. 创建 laravel 项目;8. 配置 .env 文件;9. 运行迁移;10. 通过 valet 访问项目。valet 简化了 nginx 和 dns 配置,支持 https,且资源占用低,适合大多数 laravel 本地开发需求。不同 php 版本可通过 valet 的 valet use 命令按项目切换。常见问题包括 path 配置、文件权限、数据库连接、composer 内存限制和 valet 域名解析等,均可通过对应命令和配置解决。

如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南

在 macOS 上配置并运行 Laravel 项目,核心在于搭建一个稳定且高效的 PHP 开发环境。这通常涉及到安装 Homebrew、PHP、Composer,然后选择一个本地服务器解决方案,如 Laravel Valet,最后创建并配置你的 Laravel 项目。

如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南

解决方案

要在 Mac 上搭建 Laravel 开发环境,我通常会遵循以下步骤,这套流程下来,基本上能应对绝大多数的本地开发需求:

首先,确保你的系统已经安装了 Xcode Command Line Tools,这是很多开发工具的基础。在终端运行 xcode-select --install 就可以搞定。

立即学习“PHP免费学习笔记(深入)”;

如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南

1. 安装 HomebrewHomebrew 是 macOS 上不可或缺的包管理器,它能极大简化后续 PHP、Composer 等工具的安装。

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

安装完成后,记得按照终端提示配置环境变量,确保 brew 命令可用。

如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南

2. 安装 PHP通过 Homebrew 安装 PHP 是最省心的办法。我个人偏好使用最新的稳定版,比如 PHP 8.2 或 8.3。

brew install php@8.2 # 或者你需要的其他版本

安装后,Homebrew 会自动为你处理好 PATH,但偶尔也需要手动检查一下 echo $PATH,确保 Homebrew 的 PHP 路径在系统默认 PHP 路径之前。

3. 安装 ComposerComposer 是 PHP 的依赖管理工具,Laravel 项目的基石。

brew install composer

安装完成后,你可以通过 composer --version 验证是否安装成功。

4. 安装数据库 (可选但推荐)Laravel 项目通常需要数据库。MySQL 是一个常见的选择。

brew install mysqlbrew services start mysql # 启动 MySQL 服务

你也可以选择 PostgreSQL 或 SQLite。SQLite 甚至不需要额外安装,直接在项目 .env 文件中配置即可。

5. 安装 Laravel Valet这是 macOS 上我最推荐的本地开发服务器方案。它轻量、快速,而且配置简单到令人发指。

composer global require laravel/valetvalet install

valet install 会安装 Nginx 和 DnsMasq,并将其配置为在后台运行。

6. 创建 Laravel 项目现在,你可以创建一个新的 Laravel 项目了。有两种常用方式:

通过 Laravel Installer:

composer global require laravel/installerlaravel new my-project # 创建一个名为 my-project 的新项目

通过 Composer 直接创建:

composer create-project laravel/laravel my-project

进入项目目录:cd my-project

7. 配置项目与 Valet进入你新创建的 Laravel 项目目录,然后运行:

valet park # 如果你希望 Valet 自动为你目录下的所有项目提供服务# 或者valet link # 如果你只想为当前项目创建一个特定域名

valet park 会让 Valet 监控你当前所在的父目录(比如 ~/Sites),所有子目录下的 Laravel 项目都会自动获得一个 .test 域名(例如 my-project.test)。valet link 则为当前目录创建一个符号链接,并生成一个域名。我个人更喜欢 valet park,因为我所有的项目都放在一个统一的 ~/Sites 目录下。

8. 配置 .env 文件复制 .env.example.env

cp .env.example .env

然后编辑 .env 文件,主要配置数据库连接信息。例如,如果你用了 MySQL:

DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_PORT=3306DB_DATABASE=my_project_dbDB_USERNAME=rootDB_PASSWORD=

记得在 MySQL 中创建对应的数据库 my_project_db

9. 运行迁移

php artisan migrate

这将根据你的迁移文件在数据库中创建表结构。

10. 访问项目现在,你可以在浏览器中访问 my-project.test (或者你 Valet 配置的域名) 来查看你的 Laravel 应用了。

为什么选择 Laravel Valet 而不是传统的 Nginx/Apache + PHP-FPM 组合?

说实话,对于 macOS 上的 Laravel 本地开发,我几乎是 Valet 的死忠粉。它简直就是为 Mac 用户量身定制的。

首先,极致的零配置。想想看,传统的 Nginx/Apache + PHP-FPM 组合,你需要安装 Nginx,配置虚拟主机,调整 PHP-FPM 的 sock 文件,处理权限问题,然后每次新增项目都要手动添加新的配置文件,再重启服务。这中间任何一步出错了,都可能让你浪费大量时间在排查上。Valet 呢?valet install,然后 valet parkvalet link,搞定!它会自动帮你处理好 Nginx、DnsMasq 的配置,甚至连 SSL 证书都帮你自动生成(valet secure),让你的本地项目也能跑在 HTTPS 上,这对于很多需要安全上下文的开发来说简直是福音。

其次,轻量级与高性能。Valet 运行在后台,占用资源极少。它不像 Docker 或者 Vagrant 那样需要启动一个完整的虚拟机或容器,更不像 MAMP/XAMPP 那样集成了一堆你可能用不到的服务。Valt 仅仅是利用 Nginx 和 DnsMasq 来代理请求,非常高效。对于日常的 Laravel 开发,它的速度和响应能力绝对是顶级的。

当然,如果你需要一个更接近生产环境的开发环境,或者项目涉及到复杂的微服务架构、需要特定的 Linux 环境,那 Docker 无疑是更好的选择。但对于绝大多数单一 Laravel 项目的本地开发,Valet 的便捷性和效率是无与伦比的。它让我能把更多精力放在代码本身,而不是环境配置上。

如何处理不同 Laravel 项目对 PHP 版本的要求?

这确实是个常见且让人头疼的问题。你可能手头有几个老项目跑在 PHP 7.4 上,新项目又必须用 PHP 8.2,甚至 8.3。在 macOS 上,有几种方法可以优雅地处理这个问题,我个人最常用的是结合 Homebrew 和 Valet 的特性。

Homebrew 允许你安装多个版本的 PHP。比如:

brew install php@7.4brew install php@8.2brew install php@8.3

安装后,Homebrew 会默认将最新的 PHP 版本链接到你的 PATH 中。如果你想切换全局的 PHP 版本,可以使用 brew linkbrew unlink 命令,但这种方式比较麻烦,而且容易搞混。

更推荐的做法是利用 Laravel Valet 的版本切换功能。Valet 允许你为特定的项目或目录指定 PHP 版本。

为单个项目指定 PHP 版本:进入你的项目目录,然后运行:

valet use php@7.4 # 将当前项目切换到 PHP 7.4

Valet 会自动配置 Nginx,让这个项目使用指定版本的 PHP-FPM。这个功能简直是多项目开发者的福音。

为所有项目或全局指定 PHP 版本:如果你想让所有 Valet 服务的新项目都默认使用某个 PHP 版本,可以在任何地方运行:

valet use php@8.2 # 将 Valet 的默认 PHP 版本切换到 8.2

除了 Valet,另一个更彻底的解决方案是使用 Docker。每个 Laravel 项目都可以拥有自己的 Dockerfiledocker-compose.yml 文件,完全隔离地运行在各自的容器中,拥有独立的 PHP 版本、数据库服务等。这种方式虽然初期配置成本稍高,但对于复杂的、需要高度隔离的项目来说,是终极解决方案。不过,对于仅仅是 PHP 版本切换的需求,Valet 已经足够简单高效了。

在 macOS 上搭建 Laravel 环境时常见的坑与解决方案

即便有 Valet 这样便捷的工具,在 macOS 上搭建 Laravel 环境时,还是会遇到一些“小插曲”。这些问题通常不复杂,但第一次遇到时可能让人摸不着头脑。

PATH 环境变量问题:

坑: 安装 Homebrew 或 Composer 后,终端提示命令找不到(command not found)。这通常是 ~/.zshrc~/.bash_profile 文件中 PATH 变量没有正确配置。解法: 确保 Homebrew 的 bin 目录(/usr/local/bin/opt/homebrew/bin)和 Composer 的全局 bin 目录(~/.composer/vendor/bin)在你的 PATH 中。比如,在 ~/.zshrc 中添加:

export PATH="/opt/homebrew/bin:$PATH" # For Apple Siliconexport PATH="$HOME/.composer/vendor/bin:$PATH"

然后 source ~/.zshrc 或重启终端。

文件权限问题:

坑: Laravel 项目在运行时报错,提示 storagebootstrap/cache 目录不可写。解法: 这是经典的权限问题。Laravel 需要对这两个目录有写入权限。在项目根目录运行:

chmod -R 775 storage bootstrap/cachesudo chown -R $(whoami):staff storage bootstrap/cache

$(whoami) 会自动替换为你的当前用户名。staff 是 macOS 上的默认用户组。

数据库连接问题:

坑: SQLSTATE[HY000] [2002] No such file or directoryConnection refused解法: 这通常是数据库配置问题。MySQL Socket 问题: macOS 上 Homebrew 安装的 MySQL 默认使用 socket 连接,但 PHP 有时找不到 socket 文件。在 .env 中,尝试将 DB_HOST 设置为 127.0.0.1 而不是 localhost,或者明确指定 socket 路径:

DB_HOST=127.0.0.1# 或者DB_SOCKET=/tmp/mysql.sock # 检查你的 MySQL 实际 socket 路径,通常在 /tmp 或 /var/mysql

服务未启动: 确保你的数据库服务(如 MySQL)正在运行:brew services start mysql用户名/密码错误: 检查 .env 中的 DB_USERNAMEDB_PASSWORD 是否与你的数据库用户匹配。

Composer 内存限制:

坑: 在运行 composer installcomposer update 时,遇到 Allowed memory size of X bytes exhausted 错误。解法: 增加 PHP 的内存限制。你可以临时在命令行中设置:

php -d memory_limit=-1 $(which composer) install

或者修改你的 php.ini 文件,找到 memory_limit 选项并增加其值,例如 memory_limit = 512Mmemory_limit = -1 (无限制,不推荐在生产环境使用)。

Valet 域名解析或端口冲突:

坑: *.test 域名无法访问,或者 Valet 无法启动。解法:Valet 医生: 运行 valet doctor,它会诊断常见问题并给出建议。重启 Valet: valet restart 尝试重启 Valet 服务。端口冲突: 检查是否有其他服务占用了 80 或 443 端口。你可以用 sudo lsof -i :80sudo lsof -i :443 来查看。如果 Valet 无法启动,可能是 DnsMasq 或 Nginx 配置有问题,可以尝试 valet uninstall 后再 valet install 重新安装。

这些“坑”往往是初学者最容易卡住的地方,但一旦你了解了背后的原因和解决方案,它们就变得微不足道了。总的来说,在 macOS 上搭建 Laravel 环境,虽然偶尔有些小波折,但 Laravel Valet 的出现,已经让整个过程变得异常顺畅和愉快。

以上就是如何配置MacOS运行Laravel项目 Mac上搭建Laravel PHP环境指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1289051.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何用PHP环境配置文件实现一致性 本地与生产环境配置同步
上一篇 2025年12月11日 05:24:03
如何在MacOS中切换默认PHP版本 Mac原生与自定义PHP共存管理
下一篇 2025年12月11日 05:24:13

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    100
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • JavaScript计算器开发:解决数值显示与初始化问题

    本教程深入探讨了使用JavaScript构建计算器时常见的数值显示异常问题,特别是由于类属性未初始化导致的`Cannot read properties of undefined`错误。我们将详细分析问题根源,并通过在构造函数中调用初始化方法来解决该问题,同时优化显示逻辑,确保计算器功能稳定且界面显…

    2026年5月10日
    000
  • NextAuth getToken 在服务端返回 null 的问题排查与解决

    问题描述 在使用 Next.js 和 NextAuth 构建应用程序时,有时需要在服务端获取用户的身份验证信息。getToken 函数是 NextAuth 提供的一个便捷方法,用于从请求中提取 JWT (JSON Web Token)。然而,在某些情况下,尤其是在使用 getServerSidePr…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • HTML文档如何工作?如何编辑HTML格式文件?

    HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?

    浏览器解析和渲染html的过程包括:1. 解析html构建dom树;2. 结合css构建渲染树;3. 布局计算元素位置;4. 绘制像素到屏幕。编辑html可使用记事本、vs code、sublime text等文本或代码编辑器,其中vs code因语法高亮、自动补全和插件生态成为主流选择。标准htm…

    2026年5月10日 用户投稿
    100
  • GolangWeb项目异常捕获与日志记录

    答案:通过中间件使用defer和recover捕获panic,结合zap等结构化日志库记录请求链路信息,为每个请求生成trace ID,实现异常捕获与可追踪日志,提升系统稳定性与可观测性。 在Go语言Web项目中,异常捕获与日志记录是保障系统稳定性和可维护性的关键环节。Go本身没有像其他语言那样的t…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000
  • JavaScript Electron桌面应用

    答案:使用JavaScript开发%ignore_a_1%桌面应用需结合Web技术与Node.js,通过主进程管理窗口、渲染进程展示界面,并利用IPC通信,调用系统功能如文件对话框,最后用electron-builder打包发布,注意安全与进程职责分离。 用JavaScript开发Electron桌…

    2026年5月10日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000
  • Bootstrap和MDB固定导航栏遮挡内容:如何优雅地解决页面跳转后内容被遮挡的问题?

    解决bootstrap和mdb固定导航栏遮挡内容的问题 使用Bootstrap和MDB框架构建网站时,固定导航栏遮挡内容是一个常见问题。尤其在页面跳转后,目标内容区域会被导航栏遮挡。本文提供一种优雅的解决方案,无需修改HTML结构,即可在页面跳转后自动调整滚动位置,避免内容被遮挡。 问题:点击导航链…

    2026年5月10日
    000
  • Tensorflow 音乐预测

    在本文中,我展示了如何使用张量流来预测音乐风格。在我的示例中,我比较了电子音乐和古典音乐。 你可以在我的github上找到代码:https://github.com/victordalet/sound_to_partition i – 数据集 第一步,您需要创建一个数据集文件夹,并在里面…

    2026年5月10日
    000
  • 深入理解 Laravel Session::put:避免常见陷阱与实现表单限流

    本文旨在深入探讨 laravel 框架中 `session::put` 方法的正确用法及其常见误区。针对用户在实现表单提交限流时遇到的问题,详细阐述了 `session::put` 必须提供键值对的原理,并提供了如何在控制器中利用会话机制有效防止重复提交的实战代码示例。通过本文,读者将掌握 lara…

    2026年5月10日
    000
  • Linux文件系统iostat命令使用技巧

    Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧

    iostat是Linux系统中用于监控I/O设备负载的关键工具,能分析磁盘性能并识别瓶颈。默认输出包括CPU使用率和设备I/O统计,分为系统启动以来的平均值和当前采样周期数据。核心指标有:%util反映设备利用率,持续接近100%可能表示I/O瓶颈;await为平均I/O等待时间,过高说明响应变慢;…

    2026年5月10日 用户投稿
    000
  • Voyager 中关联关系的翻译问题解决方案

    本文档旨在解决在使用 TCGVoyager 管理后台时,关联模型无法正确翻译的问题。主要针对 Laravel 项目中,使用 Voyager 1.4 版本以及 Laravel 8.0 版本,并且已经配置多语言支持的情况下,如何确保关联关系中的可翻译字段能够根据当前应用语言环境进行正确翻译。通过修改 B…

    2026年5月10日
    000
  • 如何测试html5编码_测试HTML5页面编码兼容性方法【编码测试】

    HTML5页面编码兼容性测试需五步:一查meta charset是否正确且前置;二验HTTP响应头Content-Type charset是否为utf-8;三用file或chardet工具探测实际编码;四跨浏览器测试URL参数中中文、Emoji解析;五通过W3C验证服务检查编码声明与字节一致性。 如…

    2026年5月10日
    100

发表回复

登录后才能评论
关注微信