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 时,libxml2、openssl、curl、zlib、sqlite3 是默认启用且几乎无法关闭的核心依赖。缺任何一个,configure 阶段就会报错或导致后续扩展(如 pdo_sqlite、openssl 函数)不可用。
常见错误现象:configure: error: xml2-config not found 或 ERROR: 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 实现、无需外部客户端库、支持 mysqli 和 PDO_MySQL,且自带 mysqlnd_ms、mysqlnd_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 不足以让 mysqli 或 PDO_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 => enabled和mysqli support => enabled
安装后 extension_dir 和 .so 文件缺失的排查路径
make install 完成后,mysqli 和 PDO_mysql 的模块文件(如 mysqli.so、pdo_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=mysqli和extension=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服务器多站点的配置

