apple m1系列芯片采用arm64架构,而许多传统的开发工具,如xampp,在m1 mac上运行时可能仍以x86_64(通过rosetta 2转译)模式运行其php解释器。当尝试安装php扩展时,如果扩展是为arm64架构编译的,而php解释器是x86_64架构,就会出现“mach-o file, but is an incompatible architecture (have 'arm64', need 'x86_64')”的错误。这意味着php无法加载为错误架构编译的扩展。
常见的安装尝试,如通过MacPorts、Homebrew或直接从源代码编译,可能会因为以下原因失败:
- MacPorts/Homebrew: 它们在M1 Mac上默认会尝试编译或安装ARM64版本的软件包。如果目标PHP环境是x86_64,则会导致架构不匹配。
- 源代码编译: 老旧的Phalcon版本(如3.4)可能对M1架构的编译支持不完善,或者编译过程没有正确指定目标架构,导致编译失败或生成错误的架构文件。
解决此问题的关键在于确保Phalcon扩展的编译架构与XAMPP中PHP解释器的运行架构一致。对于XAMPP在M1 Mac上运行的情况,通常意味着我们需要一个x86_64架构的Phalcon扩展。
2.1 确认XAMPP PHP的运行架构在继续之前,可以通过以下命令确认XAMPP PHP的架构:
file /Applications/XAMPP/xamppfiles/bin/php
如果输出包含 x86_64,则确认PHP解释器正在以x86_64模式运行。
2.2 下载兼容的Phalcon扩展文件由于MacPorts通常提供多种架构的预编译包,我们可以利用这一点。
-
访问MacPorts包存档: 前往MacPorts的软件包归档页面,查找对应PHP版本和Phalcon版本的x86_64架构包。例如,对于PHP 7.3和Phalcon 3.4,可以查找 php73-phalcon3 的 darwin_20.x86_64.tbz2 文件。
- 示例链接(根据实际版本调整):https://packages.macports.org/macports/packages/php73-phalcon3/php73-phalcon3-3.4.5_0.darwin_20.x86_64.tbz2
-
下载并解压: 下载该 .tbz2 文件。这是一个压缩包,解压后会得到一个包含 phalcon.so 文件的目录结构。
# 假设你下载的文件在 Downloads 目录 cd ~/Downloads tar -xvf php73-phalcon3-3.4.5_0.darwin_20.x86_64.tbz2
解压后,你会在类似 /opt/local/lib/php73/extensions/no-debug-non-zts-20180731/ 的路径下找到 phalcon.so 文件。
定位XAMPP扩展目录: XAMPP的PHP扩展目录通常位于 /Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-YYYYMMDD/,其中 YYYYMMDD 对应你的PHP版本编译日期。 你可以通过在终端运行 php -i | grep extension_dir 来找到确切的路径。
-
复制 phalcon.so 文件: 将你下载并解压得到的 phalcon.so 文件复制到XAMPP的PHP扩展目录。
# 替换为你的实际路径 sudo cp /path/to/downloaded/phalcon.so /Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-20180731/
编辑 php.ini: 打开XAMPP的 php.ini 文件。通常位于 /Applications/XAMPP/xamppfiles/etc/php.ini。
-
添加扩展配置: 在 php.ini 文件的末尾或扩展部分添加以下行:
extension=phalcon.so
保存并关闭文件。
为了让PHP加载新的扩展,你需要重启XAMPP的Apache服务。可以通过XAMPP控制面板或命令行完成:
sudo /Applications/XAMPP/xamppfiles/bin/apachectl restart3. 验证Phalcon安装
重启服务后,可以通过以下方式验证Phalcon是否成功加载:
-
命令行验证:
php -m | grep phalcon
如果输出中包含 phalcon,则表示扩展已成功加载。
-
通过 phpinfo() 验证: 创建一个 info.php 文件,内容如下:
<?php phpinfo(); ?>
将其放置在XAMPP的 htdocs 目录中,然后通过浏览器访问 http://localhost/info.php。在页面中搜索“phalcon”,如果能找到Phalcon的相关信息,则表示安装成功。
- 版本匹配: 确保下载的Phalcon扩展版本与你的PHP版本兼容。例如,Phalcon 3.x 通常与 PHP 7.x 兼容,而 Phalcon 4.x/5.x 则可能需要 PHP 8.x。
- XAMPP更新: 如果XAMPP未来发布了原生支持ARM64的PHP版本,那么此方法可能不再适用,届时应优先使用ARM64架构的Phalcon扩展。
- 路径准确性: 在执行复制和配置操作时,请务必确认XAMPP和PHP扩展的实际路径。
- 权限问题: 在复制文件或修改配置文件时,可能需要 sudo 权限。
通过上述步骤,即使在Apple M1 Mac上,也能成功地为XAMPP环境安装和配置Phalcon PHP扩展,克服架构不兼容的难题。此方法的核心在于理解并匹配PHP解释器与扩展的二进制架构。
以上就是在Apple M1 Mac上安装Phalcon PHP扩展的架构兼容性解决方案的详细内容,更多请关注知识资源分享宝库其它相关文章!
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。