Files
static-php-cli/docs/zh/guide/first-build.md

189 lines
6.3 KiB
Markdown
Raw Normal View History

2026-04-19 11:49:55 +08:00
# 第一次构建
本页通过完整的示例演示如何从零开始构建一个静态 PHP 二进制。
::: tip
如果你采用的是 spc 二进制方式安装,请将本章节中的所有 `spc` 替换为 `./spc``.\spc.exe`
如果你采用的是源码安装,请将 `spc` 替换为 `bin/spc`
:::
## 两种构建方式
StaticPHP 提供两种构建方式,根据使用场景选择:
| 方式 | 适合场景 |
|--------------|--------------------------|
| `craft` 一键构建 | 日常使用、快速上手 |
2026-04-19 18:01:56 +08:00
| 分步构建 | 细化构建流程 |
2026-04-19 11:49:55 +08:00
## 方式一:`craft` 一键构建(推荐)
`craft` 命令读取一个 `craft.yml` 配置文件自动完成依赖下载、库编译、PHP 构建的全流程。
### 编写 craft.yml
在当前目录创建 `craft.yml`,声明要编译的 PHP 版本、扩展和目标 SAPI
```yaml
2026-05-11 09:48:31 +08:00
php-version: 8.5
2026-04-19 11:49:55 +08:00
extensions: bcmath,posix,phar,zlib,openssl,curl,fileinfo,tokenizer
sapi:
- cli
- micro
```
不想手动编写?试试[命令行生成器](./cli-generator)自动生成配置。
### 开始构建
```bash
spc craft
```
构建过程依次执行:下载依赖 → 编译依赖库 → 编译 PHP。全程无需人工干预。
如需查看详细日志,加上 `-v``-vv``-vvv` 参数:
```bash
spc craft -v
```
### 查看产物
构建成功后,产物均位于 `buildroot/bin/`
| SAPI | 产物路径 |
|------------|------------------------------------------------------|
| cli | `buildroot/bin/php`Windows`buildroot/bin/php.exe` |
| fpm | `buildroot/bin/php-fpm` |
| micro | `buildroot/bin/micro.sfx` |
| embed | `buildroot/lib/libphp.a` |
| frankenphp | `buildroot/bin/frankenphp` |
验证一下 cli 是否可用:
```bash
./buildroot/bin/php -v
./buildroot/bin/php -m
```
## 方式二:分步构建
分步方式适合需要将下载与编译拆分为独立阶段的场景,例如在 CI 中缓存下载内容以加速后续构建。
### 第一步:下载依赖
v3 版本中你可以省略这一步骤直接构建想要的内容StaticPHP 会自动下载所需的依赖库和扩展源码。
但如果你想提前下载,或在网络环境较差的情况下分阶段构建,可以使用 `download` 命令:
```bash
# 按扩展列表下载(推荐,只下载实际需要的内容)
2026-05-11 09:48:31 +08:00
spc download --for-extensions="bcmath,posix,phar,zlib,openssl,curl,fileinfo,tokenizer" --with-php=8.5
2026-04-19 11:49:55 +08:00
# 按依赖包列表下载
2026-05-11 09:48:31 +08:00
spc download "curl,openssl" --with-php=8.5
2026-04-19 11:49:55 +08:00
```
下载内容缓存在 `downloads/` 目录,重复构建时会直接复用。
```bash
# 网络较慢时,可增大并发数和重试次数
2026-04-19 18:01:56 +08:00
spc download --for-extensions="bcmath,openssl,curl" --parallel 10 --retry=3
2026-04-19 11:49:55 +08:00
# 优先使用预编译的二进制依赖,跳过源码编译(大幅加速构建)
2026-04-19 18:01:56 +08:00
spc download --for-extensions="bcmath,openssl,curl" --prefer-binary
2026-04-19 11:49:55 +08:00
```
### 第二步:构建 PHP
```bash
# 构建 cli SAPI
2026-04-19 18:01:56 +08:00
spc build:php "bcmath,phar,zlib,openssl,curl,fileinfo,tokenizer" --build-cli
2026-04-19 11:49:55 +08:00
# 同时构建多个 SAPI
2026-04-19 18:01:56 +08:00
spc build:php "bcmath,phar,zlib,openssl,curl" --build-cli --build-micro
2026-04-19 11:49:55 +08:00
```
#### 常用构建选项
| 选项 | 说明 |
|----------------------|--------------------------------------|
| `--build-cli` | 构建 cli SAPI |
| `--build-fpm` | 构建 php-fpm不支持 Windows |
| `--build-micro` | 构建 micro.sfx |
| `--build-embed` | 构建嵌入式 SAPI |
| `--build-frankenphp` | 构建 FrankenPHP |
| `--enable-zts` | 启用线程安全ZTS版本 |
| `--no-strip` | 保留调试符号,不精简二进制 |
| `-I key=value` | 硬编译 INI 选项到 PHP 中 |
| `--with-upx-pack` | 用 UPX 压缩产物(需先 `spc install-pkg upx` |
硬编译 INI 的例子——预设更大的内存限制,并禁用 `system` 函数:
```bash
2026-04-19 18:01:56 +08:00
spc build:php "bcmath,pcntl,posix" --build-cli -I "memory_limit=4G" -I "disable_functions=system"
2026-04-19 11:49:55 +08:00
```
## 打包 micro 应用
构建 `micro.sfx` 后,用 `micro:combine` 将你的 PHP 代码打包进去,生成一个完全独立的可执行文件:
```bash
echo "<?php echo 'Hello, World!' . PHP_EOL;" > hello.php
spc micro:combine hello.php --output=hello
./hello
```
也支持打包 `.phar` 文件,以及注入 INI 配置:
```bash
# 打包 phar
spc micro:combine your-app.phar --output=your-app
# 打包时注入 INI
spc micro:combine your-app.phar --output=your-app -I "memory_limit=512M"
# 从 ini 文件注入配置
spc micro:combine your-app.phar --output=your-app -N /path/to/custom.ini
```
## 调试与重新构建
构建失败,或想查看详细过程,使用 `-v` / `-vv` / `-vvv`
- `-v` 将显示 `INFO` 级别的日志,包含执行到的模块和执行的编译命令等。
- `-vv` 将显示 `DEBUG` 级别的日志,包含所有 StaticPHP 中调试级别的日志。
- `-vvv` 将显示 `DEBUG` 级别的日志,并将其他 shell 命令执行的 STDOUT 输出到终端。
```bash
2026-04-19 18:01:56 +08:00
spc build:php "bcmath,openssl" --build-cli -vv
2026-04-19 11:49:55 +08:00
```
或者,你也可以查看 `log/spc.shell.log``log/spc.output.log` 获取终端输出和 StaticPHP 日志。
如需清理编译中间产物、从头重新构建(不重新下载),使用 `reset`
```bash
spc reset
# 然后重新构建
2026-04-19 18:01:56 +08:00
spc build:php "bcmath,openssl" --build-cli
2026-04-19 11:49:55 +08:00
```
::: tip
`reset` 只清理 `buildroot/``source/` 目录,不会删除 `downloads/` 缓存。
如需同时清理下载缓存,加上 `--with-download` 参数。
:::
如果问题持续无法解决,欢迎提交 [Issue](https://github.com/crazywhalecc/static-php-cli/issues),并附上 `craft.yml`(如有)和 `log/` 目录的压缩包。
## 接下来
2026-04-19 18:01:56 +08:00
- [PHP SAPI 构建参考](./sapi-reference) - 各个 PHP 的 SAPI 构建及使用指南
2026-04-19 11:49:55 +08:00
- [命令行参考](./cli-reference) — 所有命令与选项的完整说明
- [扩展列表](./extensions) — 查看支持的扩展及其依赖关系
- [常见问题](./troubleshooting) — 构建失败时的排查指南