php下载安装需要哪些依赖库_mysql扩展安装说明【汇总】

发布时间 - 2026-01-02 00:00:00    点击率:
PHP编译安装的硬性依赖为libxml2、openssl、curl、zlib、sqlite3,缺一则configure报错;MySQL扩展需同时启用--enable-mysqlnd、--with-mysqli=mysqlnd和--with-pdo-mysql=mysqlnd。

PHP 安装时哪些系统库是硬性依赖

Linux 下编译安装 PHP 时,libxml2opensslcurlzlibsqlite3 是默认启用且几乎无法关闭的核心依赖。缺任何一个,configure 阶段就会报错或导致后续扩展(如 pdo_sqliteopenssl 函数)不可用。

常见错误现象:configure: error: xml2-config not foundERROR: Cannot find OpenSSL's ,本质就是对应开发包没装。

  • Ubuntu/Debian:运行 sudo apt install libxml2-dev libssl-dev libcurl4-openssl-dev zlib1g-dev libsqlite3-dev
  • CentOS/RHEL:运行 sudo yum install libxml2-devel openssl-devel curl-devel zlib-devel sqlite-devel(RHEL 8+ 换成 dnf
  • 注意必须装 -dev-devel 后缀的包,仅装运行时库(如 libssl1.1)不够

mysqlnd 和 libmysqlclient 的区别与选型

PHP 7.4+ 默认使用 mysqlnd(MySQL Native Driver),它纯 PHP 实现、无需外部客户端库、支持 mysqliPDO_MySQL,且自带 mysqlnd_msmysqlnd_qc 等高级特性。而旧式 libmysqlclient 依赖 MySQL 官方 C 客户端,已逐步弃用。

如果你在 configure 里加了 --with-mysqli=mysqlnd--with-pdo-mysql=mysqlnd,就明确启用了 mysqlnd;若写成 --with-mysqli=/usr 或类似路径,则强制走 libmysqlclient,容易因版本不兼容导致 mysqli_connect(): (HY000/2054): The server requested authentication method unknown to the client

  • 推荐始终用 --with-mysqli=mysqlnd--with-pdo-mysql=mysqlnd
  • 不需要额外安装 MySQL 服务端或客户端二进制,但需确保 pkg-config 可查到 mysqlnd(通常默认满足)
  • 若必须用 libmysqlclient(如对接老 Oracle MySQL 5.6),请确认系统中 mysql_config 命令存在且版本 ≥ 5.5

PHP 编译时开启 MySQL 扩展的实际参数组合

单独加 --enable-mysqlnd 不足以让 mysqliPDO_MySQL 可用,必须配合对应扩展开关。常见遗漏是只开 mysqlnd 却没开上层接口。

以下是最小可用组合(以 PHP 8.2 为例):

./configure \
--enable-mysqlnd \
--with-mysqli=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-openssl \
--with-zlib

关键点:

  • --enable-mysqlnd 是基础驱动,必须最先启用
  • --with-mysqli--with-pdo-mysql 必须显式设为 mysqlnd,不能留空或写 yes
  • 如果还用到 mysql_xdevapi(X Protocol),需额外加 --enable-mysqlnd-experimental-http(PHP 8.2+)
  • configure 后检查输出里是否含 mysqlnd => enabledmysqli support => enabled

安装后 extension_dir 和 .so 文件缺失的排查路径

make install 完成后,mysqliPDO_mysql 的模块文件(如 mysqli.sopdo_mysql.so)默认生成在 modules/ 目录下,但不会自动复制到 extension_dir 指向的位置,也不会写入 php.ini

典型问题:php -m | grep mysqli 无输出,或 phpinfo() 里看不到 MySQL 相关模块。

  • 先确认模块是否存在:ls $(php-config --extension-dir)/mysqli.so,若不存在,说明 configure 阶段未启用或 make 失败
  • 手动启用:在 php.ini 中添加 extension=mysqliextension=pdo_mysql(PHP 7.0+ 支持不带 .so 后缀)
  • 注意顺序:mysqli 应在 pdo_mysql 之前加载(因后者依赖前者)
  • 若用 php-fpm,改完 ini 后必须重启 php-fpm 进程,仅 reload 不生效

mysqlnd 本身是内建驱动,不生成独立 .so 文件,所以看不到 mysqlnd.so 是正常的——它被静态链接进 PHP 主二进制里了。


# mysql  # php  # oracle  # linux  # centos  # ubuntu  # ssl  # curl  # dnf  # 区别 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 佛山网站制作系统,佛山企业变更地址网上办理步骤?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  Laravel如何自定义错误页面(404, 500)?(代码示例)  如何快速重置建站主机并恢复默认配置?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何在万网自助建站平台快速创建网站?  原生JS实现图片轮播切换效果  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  Linux安全能力提升路径_长期防护思维说明【指导】  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  怎么用AI帮你设计一套个性化的手机App图标?  javascript中的try catch异常捕获机制用法分析  香港服务器WordPress建站指南:SEO优化与高效部署策略  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  Laravel如何实现用户注册和登录?(Auth脚手架指南)  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  EditPlus中的正则表达式实战(6)  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  在centOS 7安装mysql 5.7的详细教程  高端建站三要素:定制模板、企业官网与响应式设计优化  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  JavaScript Ajax实现异步通信  长沙做网站要多少钱,长沙国安网络怎么样?  轻松掌握MySQL函数中的last_insert_id()  网站建设保证美观性,需要考虑的几点问题!  如何在云指建站中生成FTP站点?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  Laravel如何与Pusher实现实时通信?(WebSocket示例)  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  C++用Dijkstra(迪杰斯特拉)算法求最短路径  laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  JavaScript如何实现倒计时_时间函数如何精确控制  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  如何选择可靠的免备案建站服务器?  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  实例解析Array和String方法  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  javascript中对象的定义、使用以及对象和原型链操作小结  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  油猴 教程,油猴搜脚本为什么会网页无法显示?  如何用PHP快速搭建高效网站?分步指南  python中快速进行多个字符替换的方法小结  Android滚轮选择时间控件使用详解  如何快速辨别茅台真假?关键步骤解析  Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】  详解阿里云nginx服务器多站点的配置