如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式

在macos上使用valet部署php站点的核心步骤为:1. 安装homebrew;2. 安装composer;3. 全局安装valet;4. 执行valet install配置服务;5. 使用valet park或valet link部署项目。valet通过nginx、dnsmasq和php fpm实现“零配置”本地php站点运行,无需虚拟主机设置,资源占用低,操作简洁高效。相比mamp、xampp等集成环境,valet更轻量且专注web服务器核心功能,不捆绑数据库和图形界面,适合多项目快速切换。常见问题如服务异常可通过valet restart解决,php版本切换支持全局设置,域名解析问题可借助valet diagnose或重装valet处理。valet内置多种框架驱动,如laravel、wordpress等,自动识别并优化配置,提升开发效率。

如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式

在macOS上快速搭建PHP开发环境,Valet无疑是我用过最简洁、高效的工具。它巧妙地利用Nginx、DnsMasq和PHP FPM,以极低的资源占用和“零配置”的理念,让你能够瞬间启动并运行本地PHP站点,无需繁琐的虚拟主机设置或庞大的集成环境。

如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式

解决方案

要使用Valet在Mac上部署PHP站点,核心步骤非常直接。我个人觉得,它把那些复杂的服务配置都封装得很好,你只需要几个命令就能搞定。

首先,确保你的Mac上安装了Homebrew,这是macOS上包管理的基石。如果你还没装,终端里跑一下这个:

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

如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式

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

Homebrew搞定后,我们需要Composer,PHP的依赖管理工具。Valet本身就是通过Composer安装的。

brew install composer

接着,就是安装Valet本体了。这里我通常会选择全局安装,这样它就能在任何地方被调用:

如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式

composer global require laravel/valet

安装完Valet的依赖后,还需要让Valet在你的系统里“安家落户”,配置Nginx和DnsMasq:

valet install

valet install 命令会做几件事:它会安装并配置Nginx、DnsMasq,并把它们设置为开机自启动的服务。DnsMasq负责将你本地的 .test 域名(默认后缀)解析到 127.0.0.1,这样你访问 your-project.test 就能指向本地站点了。Nginx则负责处理HTTP请求。

现在,你的Valet环境已经搭建好了。要部署一个PHP站点,你只需要进入你的项目目录,然后执行:

valet park

或者,如果你只想让某个特定目录作为站点根目录,而不是整个父目录下的所有子目录都变成站点,你可以用 valet link

cd ~/Sites/my-php-projectvalet link my-php-project

这样,你就可以在浏览器里通过 http://my-php-project.test 访问你的项目了。我用它搭建过几十个WordPress站,那种丝滑感是MAMP、XAMPP这些大块头给不了的。

Valet与传统WAMP/LAMP/MAMP环境有何不同?

说实话,刚开始接触Valet的时候,我也好奇它跟MAMP、XAMPP这些老牌集成环境有什么本质区别。用了一段时间后,我发现它们的设计哲学完全不同。

MAMP、XAMPP这类工具,往往是“一站式”解决方案,它们通常会打包Apache、MySQL、PHP以及phpMyAdmin等,提供一个图形界面让你启动、停止服务,配置虚拟主机。这对于新手来说很友好,因为所有东西都在一个包里。但缺点也显而易见:它们通常比较臃肿,资源占用高,而且你可能并不需要所有这些组件。比如,如果你只做PHP开发,Apache可能就显得有些“重”了,Nginx在处理静态文件和并发连接方面往往更高效。

Valet则走的是“极简主义”路线。它不提供庞大的图形界面,完全基于命令行操作。它只专注于Web服务器(Nginx)、DNS解析(DnsMasq)和PHP运行环境(PHP FPM)。数据库呢?它不会帮你装,你可以单独安装MySQL或PostgreSQL,或者用Docker。这种“只做一件事,并把它做好”的理念,让Valet变得极其轻量和快速。

更关键的是,Valet的“零配置”特性。你不需要手动编辑Nginx配置文件来为每个项目设置虚拟主机。valet park 命令会把你指定的一个目录下的所有子目录都自动注册为可访问的站点(例如,~/Sites/project-a 会变成 project-a.test)。这种自动化的域名解析和站点服务,大大简化了多项目开发的管理。对我来说,这意味着我可以快速切换项目,不用每次都去配置一遍。

Valet在实际开发中可能遇到的常见问题及解决方案

Valet虽然好用,但在实际使用中,也偶尔会遇到一些小插曲。不过,好在它设计得比较健壮,大部分问题都有直接的解决方案。

一个比较常见的场景是,当你更新了PHP版本或者Valet自身时,服务可能会出现一些小毛病。比如,某个站点突然访问不了,或者PHP版本不对。这时候,我通常会先尝试最简单的“重启大法”:

valet restart

这个命令会重启Valet所管理的所有服务(Nginx、DnsMasq和PHP FPM),通常能解决大部分临时的配置或服务启动问题。

另一个经常遇到的问题是PHP版本切换。Mac上可能安装了多个PHP版本(比如PHP 7.4、8.0、8.1等)。Valet默认会使用Homebrew安装的最新PHP版本。但如果你的项目依赖特定PHP版本,或者你想在不同项目之间切换PHP版本,Valet提供了非常方便的命令:

valet use php@8.1 # 切换到PHP 8.1valet use php@7.4 # 切换到PHP 7.4

这会全局切换Valet使用的PHP版本。如果你想某个特定项目使用不同的PHP版本,Valet目前没有直接的“按项目切换”功能,但你可以考虑使用phpbrewasdf这类更专业的PHP版本管理工具,或者通过Nginx配置来指定。不过,对于大多数场景,全局切换已经足够了。

有时候,你可能会遇到 .test 域名解析失败的情况。这通常是DnsMasq出了问题。你可以尝试运行 valet diagnose 来检查Valet的运行状态和配置,它会给出一些诊断信息,帮助你定位问题。如果问题依然存在,可以尝试卸载并重新安装Valet:

valet uninstallcomposer global remove laravel/valet# 确保删除 ~/.config/valet 目录rm -rf ~/.config/valet# 然后重新执行安装步骤composer global require laravel/valetvalet install

这几乎是“万能药”,能解决大多数疑难杂症,因为它清除了所有旧的配置并重新构建。

Valet如何支持Laravel、WordPress等主流PHP框架和CMS?

Valet对主流PHP框架和CMS的支持,是我选择它的一个重要原因。它内置了多种“驱动”(drivers),能够自动识别项目类型并进行相应的配置,这省去了大量的手动调整。

当你把一个Laravel项目放到Valet管理的目录下(比如通过valet park),Valet会自动识别这是一个Laravel应用。你访问 your-laravel-project.test 时,Valet会智能地将请求路由到Laravel项目的public目录,并启动Laravel的请求生命周期。你不需要做任何额外配置,就像魔法一样。

对于WordPress也是如此。Valet有一个专门的WordPress驱动。当你把一个WordPress安装目录放到valet park的目录下,Valet就能识别它,并正确地处理WordPress的URL重写规则(比如漂亮的固定链接)。我经常用Valet来快速搭建临时的WordPress开发环境,进行主题或插件开发测试,效率非常高。

除了Laravel和WordPress,Valet还支持许多其他框架和CMS,包括Symfony、Zend Framework、Statamic、Jigsaw等等。这种开箱即用的兼容性,让开发者可以专注于代码本身,而不是环境配置。

从性能角度看,Valet由于其轻量级的设计,表现非常出色。Nginx作为Web服务器,在处理静态文件和高并发请求方面有着天然优势,而PHP FPM则能高效地管理PHP进程。这一切都在本地运行,资源占用极小,对于MacBook用户来说,这意味着更长的电池续航和更安静的风扇。我个人感觉,Valet在本地开发环境中的响应速度,比那些基于Apache的集成环境要快不少,尤其是在同时跑好几个项目的时候。它能自动启用HTTPS(通过 valet secure 命令),这对于本地开发需要模拟生产环境的HTTPS行为时,也提供了极大的便利。

以上就是如何使用Valet在Mac搭建PHP环境 MacOS下快速PHP站点部署方式的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 09:49:01
下一篇 2025年12月10日 09:49:08

相关推荐

  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • HTMLrev 上的免费 HTML 网站模板

    HTMLrev 是唯一的人工策划的库专门专注于免费 HTML 模板,适用于由来自世界各地慷慨的模板创建者制作的网站、登陆页面、投资组合、博客、电子商务和管理仪表板世界。 这个人就是我自己 Devluc,我已经工作了 1 年多来构建、改进和更新这个很棒的免费资源。我自己就是一名模板制作者,所以我知道如…

    2025年12月24日
    300
  • 如何使用 Laravel 框架轻松整合微信支付与支付宝支付?

    如何通过 laravel 框架整合微信支付与支付宝支付 在 laravel 开发中,为电商网站或应用程序整合支付网关至关重要。其中,微信支付和支付宝是中国最流行的支付平台。本文将介绍如何使用 laravel 框架封装这两大支付平台。 一个简单有效的方法是使用业内认可的 easywechat lara…

    2025年12月24日
    000
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • Laravel 框架中如何无缝集成微信支付和支付宝支付?

    laravel 框架中微信支付和支付宝支付的封装 如何将微信支付和支付宝支付无缝集成到 laravel 框架中? 建议解决方案 考虑使用 easywechat 的 laravel 版本。easywechat 是一个成熟、维护良好的库,由腾讯官方人员开发,专为处理微信相关功能而设计。其 laravel…

    2025年12月24日
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 使用Laravel框架如何整合微信支付和支付宝支付?

    使用 Laravel 框架整合微信支付和支付宝支付 在使用 Laravel 框架开发项目时,整合支付网关是常见的需求。对于微信支付和支付宝支付,推荐采用以下方法: 使用第三方库:EasyWeChat 的 Laravel 版本 建议直接使用现有的 EasyWeChat 的 Laravel 版本。该库由…

    2025年12月24日
    000
  • 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中?

    如何简洁集成微信和支付宝支付到 Laravel 问题: 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中? 答案: 强烈推荐使用流行的 Laravel 包 EasyWeChat,它由腾讯开发者维护。多年来,它一直保持更新,提供了一个稳定可靠的解决方案。 集成步骤: 安装 Laravel …

    2025年12月24日
    100
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信