PHP纯离线搭建(php 8.1.7)
要离线从零安装 PHP 8.1.7,需要准备好 PHP 的源代码以及所有相关的依赖包。以下是步骤:
步骤概览
在联网系统上下载 PHP 8.1.7 源代码和所有依赖包。
将这些文件传输到离线系统。
安装所需的依赖包。
编译并安装 PHP 8.1.7。
配置 PHP 和 Web 服务器。
- 在联网系统上下载 PHP 8.1.7 和依赖库
步骤 1: 下载 PHP 8.1.7 源代码
在联网的系统上,首先下载 PHP 8.1.7 源代码:
wget https://www.php.net/distributions/php-8.1.7.tar.gz (或者浏览器直接输入该地址下载)
步骤 2: 下载依赖包
要编译 PHP,需要安装必要的编译工具和依赖包。可以使用包管理工具下载这些包。
对于 Ubuntu/Debian 系统
安装编译 PHP 所需的依赖包:
sudo apt-get install build-essential autoconf bison re2c libxml2-dev libsqlite3-dev libcurl4-openssl-dev libjpeg-dev libpng-dev libxpm-dev libfreetype6-dev libmcrypt-dev libssl-dev pkg-config
要离线下载这些包,可以使用以下命令在联网机器上下载依赖包:
apt-get download <package_name>
例如:
apt-get download build-essential autoconf bison re2c libxml2-dev libsqlite3-dev libcurl4-openssl-dev libjpeg-dev libpng-dev libxpm-dev libfreetype6-dev libssl-dev pkg-config
对于 CentOS/RHEL 系统
下载 CentOS 或 RHEL 上所需的依赖包:
sudo yum groupinstall “Development Tools”
sudo yum install libxml2-devel bzip2-devel curl-devel libpng-devel libjpeg-devel freetype-devel openssl-devel sqlite-devel oniguruma-devel
可以使用 yumdownloader 下载这些包:
yumdownloader <package_name>
步骤 3: 打包下载的文件
将 PHP 源代码和所有依赖包打包:
tar -czvf php8.1.7_offline_install.tar.gz php-8.1.7.tar.gz <dependency_files>
2. 将文件传输到离线系统
将打包的文件传输到离线系统,可以使用 USB 或 scp 等工具。
scp php8.1.7_offline_install.tar.gz user@offline_server:/path/to/destination
3. 在离线系统上安装依赖包
步骤 1: 解压文件
在离线系统上,首先解压传输过来的打包文件:
tar -xzvf php8.1.7_offline_install.tar.gz
步骤 2: 安装依赖包
对于 Ubuntu/Debian 系统
sudo dpkg -i *.deb
对于 CentOS/RHEL 系统
sudo rpm -i *.rpm
4. 编译和安装 PHP 8.1.7
步骤 1: 解压 PHP 源代码
tar -xzvf php-8.1.7.tar.gz
cd php-8.1.7
步骤 2: 配置编译选项
根据需要配置 PHP 编译选项。以下是常见的编译选项:
./configure --prefix=/usr/local/php8
–with-config-file-path=/usr/local/php8
–with-config-file-scan-dir=/usr/local/php8/conf.d
–enable-mbstring
–enable-intl
–with-openssl
–with-zlib
–enable-pcntl
–enable-sockets
–enable-soap
–with-curl
–enable-fpm
–with-mysqli
–with-pdo-mysql
–with-zlib
–enable-bcmath
–enable-ftp
–with-gd
–enable-gd
–with-jpeg
–with-freetype
步骤 3: 编译和安装 PHP
编译 PHP:
make
安装 PHP:
sudo make install
步骤 4: 配置 PHP
拷贝 PHP 配置文件模板:
cp php.ini-production /usr/local/php8/php.ini
编辑 php.ini,根据需要修改配置:
sudo nano /usr/local/php8/php.ini
5. 配置 Web 服务器
配置 Nginx 和 PHP-FPM
启动 PHP-FPM:
/usr/local/php8/sbin/php-fpm
修改 Nginx 配置,使其使用 PHP-FPM,编辑 /etc/nginx/nginx.conf 或虚拟主机配置文件:
nginx
location ~ .php$ {
include fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME d o c u m e n t r o o t document_root documentrootfastcgi_script_name;
}
重启 Nginx:
sudo systemctl restart nginx
配置 Apache 和 PHP
确保已安装 Apache,并安装 libapache2-mod-php8.1。
sudo apt-get install apache2 libapache2-mod-php8.1
重启 Apache:
sudo systemctl restart apache2
6. 测试 PHP 安装
创建测试 PHP 文件:
sudo nano /var/www/html/info.php
内容如下:
php
<?php phpinfo(); ?>打开浏览器,访问 http://your_server_ip/info.php,确认 PHP 8.1.7 已成功安装。
总结
在联网系统上下载 PHP 源代码和依赖包。
将所有文件传输到离线系统。
安装依赖包,编译并安装 PHP 8.1.7。
配置 PHP 和 Web 服务器(Nginx 或 Apache)。
您说:
进行 ./configure 时报了no package ‘oniguruma’ found
在进行 PHP 编译时,oniguruma 是用于支持多字节正则表达式(用于 mbstring 扩展)的库。如果编译时提示没有找到 oniguruma,需要手动安装这个库。
解决方法:
- 下载并安装 oniguruma 库
因为是离线安装,所以需要在有网络的机器上下载 oniguruma 源代码或包,之后再将其安装到目标系统中。
步骤 1: 下载 oniguruma 源代码
在有网络的机器上,下载 oniguruma 的源代码。oniguruma 的源代码托管在 GitHub 上:
wget https://github.com/kkos/oniguruma/releases/download/v6.9.7/onig-6.9.7.tar.gz
将下载的压缩包传输到目标离线系统。
步骤 2: 在离线系统上解压并编译 oniguruma
解压下载的文件:
tar -xzvf onig-6.9.7.tar.gz
cd onig-6.9.7
编译并安装 oniguruma:
./configure
make
sudo make install
步骤 3: 确认 oniguruma 安装成功
执行以下命令,确认 oniguruma 库已成功安装:
pkg-config --modversion oniguruma
如果输出了版本号,例如 6.9.7,说明 oniguruma 安装成功。
- 编译 PHP 时重新指定 oniguruma
在 PHP 的编译过程中,确保指定了正确的路径来找到 oniguruma。可以通过以下命令再次配置 PHP:
./configure --with-onig=/usr/local
如果安装路径不同,可以替换 /usr/local 为 oniguruma 实际安装的路径。
总结
下载并编译 oniguruma 库。
安装完成后,重新运行 ./configure 配置 PHP,并确保指定了 oniguruma 的路径。
您说:
fail to load configuration file ‘/usr/local/php/etc/php-fpm.conf’
回答:
如果在启动 PHP-FPM 时遇到 “fail to load configuration file ‘/usr/local/php/etc/php-fpm.conf’” 错误,通常是因为配置文件路径不正确或配置文件丢失。下面是解决这个问题的步骤:
步骤 1: 确认 php-fpm.conf 文件路径
确保 php-fpm.conf 文件存在于指定路径 /usr/local/php/etc/ 中。
ls -l /usr/local/php/etc/php-fpm.conf
如果文件不存在或路径不对,需要重新检查或创建配置文件。
步骤 2: 创建 php-fpm.conf 配置文件
如果配置文件丢失,可以从 PHP 的源代码中复制默认配置文件,或者从其他 PHP 安装中获取默认配置文件。可以使用以下命令来创建一个基本的 php-fpm.conf 配置文件:
sudo cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
如果 /usr/local/php/etc/php-fpm.conf.default 文件不存在,可以从 PHP 源代码目录中复制:
cp /path/to/php-8.1.7/php-fpm.conf /usr/local/php/etc/php-fpm.conf
步骤 3: 确保配置文件的正确性
打开配置文件并检查是否存在错误:
sudo nano /usr/local/php/etc/php-fpm.conf
确保配置文件中的路径、权限和其他设置都正确。以下是一个简单的配置示例:
ini
复制代码
[global]
error_log = /usr/local/php/var/log/php-fpm.log
pid = /usr/local/php/var/run/php-fpm.pid
[www]
user = www-data
group = www-data
listen = /usr/local/php/var/run/php-fpm.sock
listen.mode = 0660
pm = dynamic
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3
步骤 4: 检查配置目录权限
确保 PHP-FPM 配置目录 /usr/local/php/etc/ 和其他相关目录具有正确的权限和所有权:
sudo chown -R root:root /usr/local/php/etc
sudo chmod -R 755 /usr/local/php/etc
步骤 5: 检查 PHP-FPM 是否可以启动
尝试手动启动 PHP-FPM 并查看输出中的错误信息:
/usr/local/php/sbin/php-fpm -t
这会检查配置文件的语法错误。如果一切正常,你应该看到类似于 “configuration file /usr/local/php/etc/php-fpm.conf test is successful” 的消息。
然后可以尝试启动 PHP-FPM 服务:
/usr/local/php/sbin/php-fpm
步骤 6: 查看日志文件
如果仍然遇到问题,可以查看 PHP-FPM 的日志文件以获取更多信息:
sudo tail -f /usr/local/php/var/log/php-fpm.log
总结
确认 php-fpm.conf 文件存在于 /usr/local/php/etc/。
如果文件丢失,创建一个新的配置文件。
检查配置文件的路径、权限和设置是否正确。
使用 php-fpm -t 命令检查配置文件的语法。
启动 PHP-FPM 服务并查看日志文件以获取更多信息。
按照这些步骤,应该能够解决 “fail to load configuration file” 的问题。
问题
nothing matches the include pattern ‘/usr/local/php/etc/php-fpm.d/.conf’ from ‘/usr/local/php/etc/php-fpm.conf’
ChatGPT 说:
ChatGPT
如果在启动 PHP-FPM 时遇到错误 “nothing matches the include pattern '/usr/local/php/etc/php-fpm.d/.conf’ from ‘/usr/local/php/etc/php-fpm.conf’”,这表明 php-fpm.conf 文件中指定的包含目录或文件模式没有匹配到任何文件。这个问题通常发生在以下几种情况下:
/usr/local/php/etc/php-fpm.d/ 目录不存在。
/usr/local/php/etc/php-fpm.d/ 目录存在但没有配置文件。
配置文件的路径或文件模式在 php-fpm.conf 中错误。
解决步骤
步骤 1: 确认目录存在
首先,确保 /usr/local/php/etc/php-fpm.d/ 目录存在:
ls -ld /usr/local/php/etc/php-fpm.d/
如果目录不存在,可以创建它:
sudo mkdir -p /usr/local/php/etc/php-fpm.d/
步骤 2: 确认目录下的配置文件
如果目录存在,但没有配置文件,需要添加至少一个配置文件。通常,这些文件是为不同的池配置文件。例如:
sudo nano /usr/local/php/etc/php-fpm.d/www.conf
可以用以下内容作为基本示例配置:
ini
[www]
user = www-data
group = www-data
listen = /usr/local/php/var/run/php-fpm.sock
listen.mode = 0660
pm = dynamic
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3
步骤 3: 检查 php-fpm.conf 中的 include 指令
确保 php-fpm.conf 文件中的 include 指令指定了正确的目录和文件模式:
ini
include=/usr/local/php/etc/php-fpm.d/*.conf
检查该行是否拼写正确,并且指向了存在的目录和文件。
步骤 4: 测试配置文件
在修复目录和文件后,可以用以下命令测试 PHP-FPM 配置是否有效:
bash
/usr/local/php/sbin/php-fpm -t
步骤 5: 重新启动 PHP-FPM
如果配置文件和目录正确,尝试重新启动 PHP-FPM:
bash
/usr/local/php/sbin/php-fpm
步骤 6: 查看日志
如果仍然遇到问题,可以查看 PHP-FPM 的日志文件获取更多错误信息:
sudo tail -f /usr/local/php/var/log/php-fpm.log
总结
确保 /usr/local/php/etc/php-fpm.d/ 目录存在,如果不存在,则创建它。
在目录中添加至少一个配置文件,例如 www.conf。
检查 php-fpm.conf 中的 include 指令 是否正确指定了存在的目录和文件模式。
使用 php-fpm -t 命令测试配置,然后重新启动 PHP-FPM。
按照这些步骤操作后,应该能够解决 “nothing matches the include pattern” 的问题。
cannot get pid from group ‘nobody’
错误 “cannot get pid from group ‘nobody’” 通常发生在 PHP-FPM 启动时,表示 PHP-FPM 尝试使用名为 nobody 的用户或组,但系统中没有找到这个用户或组。这个问题通常与 PHP-FPM 的配置文件有关,特别是配置文件中的用户和组设置。
解决步骤
步骤 1: 确认 nobody 用户和组存在
首先,确认系统中是否存在 nobody 用户和组:
getent passwd nobody
getent group nobody
如果这些命令没有返回任何信息,说明系统中没有 nobody 用户和组。
步骤 2: 创建 nobody 用户和组
如果 nobody 用户和组不存在,你可以创建它们:
创建 nobody 组:
sudo groupadd nobody
创建 nobody 用户:
sudo useradd -r -g nobody nobody
其中 -r 选项表示创建一个系统用户。
步骤 3: 检查 PHP-FPM 配置文件
检查 PHP-FPM 配置文件 /usr/local/php/etc/php-fpm.conf 或池配置文件 /usr/local/php/etc/php-fpm.d/www.conf,确认 user 和 group 设置是否正确。例如:
ini
user = nobody
group = nobody
如果你的系统中没有 nobody 用户或组,可以将这些设置更改为系统中存在的用户和组。例如,可以使用 www-data 或 apache 用户和组(这取决于你的系统和 Web 服务器设置):
ini
user = www-data
group = www-data
步骤 4: 确保 PHP-FPM 配置文件的权限
确保 PHP-FPM 配置文件和相关目录的权限正确:
bash
sudo chown -R root:root /usr/local/php/etc/
sudo chmod -R 755 /usr/local/php/etc/
步骤 5: 测试和重启 PHP-FPM
在修改配置文件后,使用以下命令测试 PHP-FPM 配置文件:
/usr/local/php/sbin/php-fpm -t
如果配置测试通过,重新启动 PHP-FPM:
/usr/local/php/sbin/php-fpm
步骤 6: 查看日志文件
如果问题仍然存在,查看 PHP-FPM 的日志文件以获取更多信息:
sudo tail -f /usr/local/php/var/log/php-fpm.log
总结
确认 nobody 用户和组存在,如果不存在则创建它们。
检查并更新 PHP-FPM 配置文件 中的 user 和 group 设置。
确保配置文件和目录权限正确。
测试配置文件 并 重新启动 PHP-FPM。
查看日志文件 获取更多信息。
通过这些步骤,你应该能够解决 “cannot get pid from group ‘nobody’” 的问题。(或者使用存在的组,配置到user和group)
相关文章:
PHP纯离线搭建(php 8.1.7)
要离线从零安装 PHP 8.1.7,需要准备好 PHP 的源代码以及所有相关的依赖包。以下是步骤: 步骤概览 在联网系统上下载 PHP 8.1.7 源代码和所有依赖包。 将这些文件传输到离线系统。 安装所需的依赖包。 编译并安装 PHP 8.1.7。 配置 PHP 和 Web 服务器。 …...
【iOS】push和pop、present和dismiss
目录 前言push和poppushpop present和dismisspresentdismiss实现模态对话框代码示例 区别总结 前言 push 和 present 是两种用于导航和切换视图控制器(ViewController)的常用方法,push与present都可以推出新的界面,present与dismi…...

基于51单片机的两路电压检测(ADC0808)
目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于51单片机,通过ADC0808获取两路电压,通过LCD1602显示 二、硬件资源 基于KEIL5编写C代码,PROTEUS8.15进行仿真,全部资源在页尾,提供…...

JavaScript ---案例(统计字符出现次数)
统计字符出现次数 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-w…...

切换淘宝最新npm镜像源
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:前端工程师 文章目录 一、🌎前言二、🌎切换淘宝最新npm镜像源2.…...

mysql时间戳格式化yyyy-mm-dd
格式化到 年月日 # 将时间换成列名就行;当前是秒级时间戳,如果是毫秒的 / 1000即可 # SELECT FROM_UNIXTIME(1602668106666.777888999 / 1000,%Y-%m-%d) AS a; # SELECT FROM_UNIXTIME(列名 / 1000,%Y-%m-%d) AS a; SELECT FROM_UNIXTIME(1602668106.666…...

网络丢包定位记录(二)
网卡驱动丢包 查看:ifconfig eth1/eth0 等接口 1.RX errors: 表示总的收包的错误数量,还包括too-long-frames错误,Ring Buffer 溢出错误,crc 校验错误,帧同步错误,fifo overruns 以及 missed pkg 等等。 …...
深度学习自编码器 - 自编码器的应用篇
序言 在深度学习的广阔领域中,自编码器( Autoencoder \text{Autoencoder} Autoencoder)作为一种无监督学习算法,凭借其独特的数据处理与特征提取能力,在多个领域展现出巨大的应用潜力。自编码器通过编码器将输入数据映…...
Python 小工具制作 系列文章 - 总目录
【Python实战】 ---- 批量图片压缩【python实战】---- 30行代码提取个人值班表【Python实战】---- 30行代码破解加密压缩包【python 实战】---- 批量将图片转换成base64工具开发【python 实战】---- 批量将xlxs文件中的base64转换成png图片工具开发【Python 实战】---- 批量对图…...

Codeforces Round 973 (Div. 2) - D题
传送门:Problem - D - Codeforces 题目大意: 思路: 尽量要 最大值变小,最小值变大 即求 最大值的最小 和 最小值的最大 -> 二分答案 AC代码: 代码有注释 #include<bits/stdc.h> using namespace std; #…...

threejs性能优化之gltf文件压缩threejs性能优化之glb文件压缩
在使用Three.js进行3D图形开发时,GLTF(GL Transmission Format)文件因其高效性和灵活性而广受欢迎。然而,随着模型复杂度的增加,GLTF文件的大小也会显著增加,这可能会对加载时间和渲染性能产生负面影响。为…...

设计模式 享元模式(Flyweight Pattern)
享元模式 简绍 享元模式(Flyweight Pattern)是一种结构型设计模式,它的目的是通过共享技术来有效地支持大量细粒度的对象。享元模式可以极大地减少内存的使用,从而提高程序的性能。它特别适用于需要创建大量相似对象的场景&#…...
Leetcode 3290. Maximum Multiplication Score
Leetcode 3290. Maximum Multiplication Score 1. 解题思路2. 代码实现 题目链接:3290. Maximum Multiplication Score 1. 解题思路 这一题的话就是一个比较暴力的动态规划,这里就不过多展开了,参考代码看一下就行。 2. 代码实现 给出py…...

CefSharp_Vue交互(Element UI)_WinFormWeb应用(3)---通过页面锁屏和关机(含示例代码)
一、预览 实现功能:通过vue标题栏按钮锁屏和关机 1.1 预览 1.2 代码 锁屏代码csharp LockWorkStation() 关机代码chsharp 注意vue代码参数和此参数一致(0/1/2) 方法ExitWindowsEx()...
unity UnityWebRequest 的request.downloadHandler 空应用
unity UnityWebRequest 的request.downloadHandler 空应用 private IEnumerator Test_Get() {UnityWebRequest request new UnityWebRequest(tmp_getURL, "GET");yield return request.SendWebRequest();if (request.result UnityWebRequest.Result.ConnectionErr…...

使用 UWA Gears 定位游戏内存问题
UWA Gears 是UWA最新发布的无SDK性能分析工具。针对移动平台,提供了实时监测和截帧分析功能,帮助您精准定位性能热点,提升应用的整体表现。 内存不足、内存泄漏和过度使用等问题,常常导致游戏出现卡顿、崩溃,甚至影响…...

OpenRestry(一个Nginx集成工具)的安装与使用
文章目录 一、OpenRestry介绍1、什么是Nginx呢?2、Nginx的反向代理3、Nginx的作用4、什么是OpenRestry? 二、OpenRestry的安装三、OpenRestry中nginx的使用1、Ngnix可以当做web服务器2、Nginx中可以编写Lua脚本 一、OpenRestry介绍 要想了解什么是OpenR…...

linux操作系统的基本命令
1.linux下的文件系统 在linux操作目录下没有像window操作系统下盘符的概念,只有一个根目录/,所有文件目录都在它的下面 linux的目录结构: 在Linux系统中: 文件都从跟目录开始的,用/表示文件名称区分大小写路径都是以/俩进行分隔(windown用\分隔)以.开头的文件为隐藏文件 Li…...

通过UV快速计算品牌独立站网络流量
背景: 品牌独立站项目交付过程中,我们需要为客户提供“云资源” 成本报价,其中“计算资源” 及CPU、内存、存储 参数相对固定,而互联网网络成本需要进行评估报价,以海外TOP云平台 AWS、AZURE、GCP 为例都是以“不限带…...

使用Kong开源API网关的保姆级教程
什么是Kong? Kong是一个开源的、云原生、高性能的API网关,可以轻松地为任何服务提供管理、保护和扩展。它提供了一个可扩展的插件生态系统,可以满足各种各样的需求,如身份验证、授权、限流、监控等。 安装Kong 1. 环境准备 操作系统: CentOS、Ubuntu等主流Linux发行版D…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查
在对接支付宝API的时候,遇到了一些问题,记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...

对WWDC 2025 Keynote 内容的预测
借助我们以往对苹果公司发展路径的深入研究经验,以及大语言模型的分析能力,我们系统梳理了多年来苹果 WWDC 主题演讲的规律。在 WWDC 2025 即将揭幕之际,我们让 ChatGPT 对今年的 Keynote 内容进行了一个初步预测,聊作存档。等到明…...

Java-41 深入浅出 Spring - 声明式事务的支持 事务配置 XML模式 XML+注解模式
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...

零基础设计模式——行为型模式 - 责任链模式
第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...
docker 部署发现spring.profiles.active 问题
报错: org.springframework.boot.context.config.InvalidConfigDataPropertyException: Property spring.profiles.active imported from location class path resource [application-test.yml] is invalid in a profile specific resource [origin: class path re…...
CSS设置元素的宽度根据其内容自动调整
width: fit-content 是 CSS 中的一个属性值,用于设置元素的宽度根据其内容自动调整,确保宽度刚好容纳内容而不会超出。 效果对比 默认情况(width: auto): 块级元素(如 <div>)会占满父容器…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...

vulnyx Blogger writeup
信息收集 arp-scan nmap 获取userFlag 上web看看 一个默认的页面,gobuster扫一下目录 可以看到扫出的目录中得到了一个有价值的目录/wordpress,说明目标所使用的cms是wordpress,访问http://192.168.43.213/wordpress/然后查看源码能看到 这…...
MySQL 索引底层结构揭秘:B-Tree 与 B+Tree 的区别与应用
文章目录 一、背景知识:什么是 B-Tree 和 BTree? B-Tree(平衡多路查找树) BTree(B-Tree 的变种) 二、结构对比:一张图看懂 三、为什么 MySQL InnoDB 选择 BTree? 1. 范围查询更快 2…...