## 介紹
static-php-cli 是一個用于構建靜態編譯的 PHP 二進制的工具,目前支持 Linux 和 macOS 系統。
在本章節中,你將了解到如何使用 static-php-cli 構建獨立的 php 程序。
## 編譯環境[?](https://static-php.dev/zh/guide/#%E7%BC%96%E8%AF%91%E7%8E%AF%E5%A2%83)
下面是架構支持情況`??` 代表支持 GitHub Action 構建,?? 代表支持本地構建,`空`代表暫不支持。
| OS | x86\_64 | aarch64 |
| --- | --- | --- |
| macOS | ?? ?? | ?? ?? |
| Linux | ?? ?? | ?? ?? |
| Windows | ?? ?? | |
| FreeBSD | ?? | ?? |
其中,Linux 目前僅在 Ubuntu、Debian、Alpine 發行版測試通過,其他發行版未進行測試,不能保證編譯成功。 對于未經過測試的發行版,可以使用 Docker 等方式本地編譯,避免環境導致的問題。
macOS 下支持 x86\_64 和 Arm 兩種架構,但在其中一個架構上編譯的二進制無法直接在另一個架構上使用。 Rosetta 2 不能保證 Arm 架構編譯的程序可以完全運行在 x86\_64 環境下。
> Windows 目前只支持 x86\_64 架構,不支持 32 位 x86、不支持 arm64 架構。
## PHP 支持版本
目前,static-php-cli 對 PHP 7.4 ~ 8.3 版本是支持的,對于 PHP 7.4 及更早版本理論上支持,只需下載時選擇早期版本即可。 但由于部分擴展和特殊組件已對早期版本的 PHP 停止了支持,所以 static-php-cli 不會明確支持早期版本。 我們推薦你編譯盡可能新的 PHP 版本,以獲得更好的體驗。
## 本地構建
### 手動構建
本項目提供了一個 static-php-cli 的二進制文件,你可以直接下載對應平臺的二進制文件,然后使用它來構建靜態的 PHP。目前`spc`二進制支持的平臺有 Linux 和 macOS。
使用以下命令從自托管服務器下載
```
curl -fsSL -o spc https://dl.static-php.dev/static-php-cli/spc-bin/nightly/spc-linux-x86_64
```
> 更多版本:https://static-php.dev/zh/guide/manual-build.html
賦予二進制可執行權限
```
chmod +x ./spc
```
查看版本
```ts
./spc --version
static-php-cli 2.3.2
```
### 下載依賴包
使用命令`bin/spc download`可以下載編譯需要的源代碼,包括 php-src 以及依賴的各種庫的源碼。
僅下載要編譯的擴展及依賴庫(使用擴展名,包含可選庫)
```
./spc download --for-extensions=pcntl,zstd --with-php=8.2
```

### 環境檢查
如果你可以正常運行`bin/spc`但無法正常編譯靜態的 PHP 或依賴庫,可以先運行`bin/spc doctor`檢查系統自身是否缺少依賴。
```
./spc doctor
```

如果提示以下錯誤,請使用`sudo`權限
```
[11:12:22] [INFO] [EXEC] ./configure --disable-gcc-wrapper
Fix failed
Some check item are not fixed
```
cmake版本太低
```
Checking if cmake version >= 3.18 ... cmake version is too low (3.10.2), please update it manually!
Some check items can not be fixed !
```
下載解壓
```
wget https://cmake.org/files/v3.22/cmake-3.22.5.tar.gz
tar -zxvf cmake-3.22.5.tar.gz
cd cmake-3.22.5
# 編譯安裝
./configure
make
sudo make install
```

驗證安裝
```
cmake --version
cmake version 3.22.5
CMake suite maintained and supported by Kitware (kitware.com/cmake).
```
重新檢測,可以看出以下輸出信息表示環境檢查通過。
```ts
_ _ _ _
___| |_ __ _| |_(_) ___ _ __ | |__ _ __
/ __| __/ _` | __| |/ __|____| '_ \| '_ \| '_ \
\__ \ || (_| | |_| | (_|_____| |_) | | | | |_) |
|___/\__\__,_|\__|_|\___| | .__/|_| |_| .__/ v2.3.2
|_| |_|
Checking if current OS are supported ... Linux x86_64 ubuntu, supported
Checking if necessary tools are installed ... ok
Checking if musl-wrapper is installed ... ok
Checking if musl-cross-make is installed ... ok
Checking if cmake version >= 3.18 ... 3.22.5
Checking if necessary linux headers are installed ... ok
Doctor check complete !
```
### 編譯 PHP
使用 build 命令可以開始構建靜態 php 二進制,在執行`bin/spc build`命令前,務必先使用`download`命令下載資源,建議使用`doctor`檢查環境。
```
./spc build pcntl,zstd --build-cli
```

> 構建結果
```
_ _ _ _
___| |_ __ _| |_(_) ___ _ __ | |__ _ __
/ __| __/ _` | __| |/ __|____| '_ \| '_ \| '_ \
\__ \ || (_| | |_| | (_|_____| |_) | | | | |_) |
|___/\__\__,_|\__|_|\___| | .__/|_| |_| .__/ v2.3.2
|_| |_|
[14:52:49] [INFO] Build OS: Linux (x86_64)
[14:52:49] [INFO] Build SAPI: cli
[14:52:49] [INFO] Extensions (2): pcntl,zstd
[14:52:49] [INFO] Libraries (1): zstd
[14:52:49] [INFO] Strip Binaries: yes
[14:52:49] [INFO] Enable ZTS: no
[14:52:49] [INFO] PHP Version: 8.2.22
[14:52:49] [NOTI] Build will start after 2s ...
[14:52:51] [NOTI] lib [pkg-config] already built
[14:52:51] [INFO] Building required library [zstd]
[14:52:51] [INFO] Entering dir: /home/www/build/source/zstd/build/cmake/build
[14:52:51] [INFO] [EXEC] cmake -DCMAKE_C_COMPILER=x86_64-linux-musl-gcc -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/ -DCMAKE_INSTALL_BINDIR=/bin -DCMAKE_INSTALL_LIBDIR=/lib -DCMAKE_INSTALL_INCLUDEDIR=/include -DCMAKE_TOOLCHAIN_FILE=/home/www/build/source/toolchain.cmake -DZSTD_BUILD_STATIC=ON -DZSTD_BUILD_SHARED=OFF ..
[14:52:53] [INFO] [EXEC] cmake --build . -j 2
[14:54:38] [INFO] [EXEC] make install DESTDIR=/home/www/build/buildroot
[14:54:39] [INFO] Patching library [zstd] pkgconfig
[14:54:39] [INFO] lib [zstd] setup success, took 107.47 s
[14:54:39] [INFO] Entering dir: /home/www/build/source/php-src
[14:54:39] [INFO] [EXEC] ./buildconf --force
[14:54:42] [INFO] Entering dir: /home/www/build/source/php-src
[14:54:42] [INFO] pcntl is using --enable-pcntl
[14:54:42] [INFO] zstd is using --enable-zstd --with-libzstd="/home/www/build/buildroot"
[14:54:42] [INFO] [EXEC] LD_LIBRARY_PATH=/usr/local/musl/x86_64-linux-musl/lib ./configure --prefix= --with-valgrind=no --enable-shared=no --enable-static=yes --disable-all --disable-cgi --disable-phpdbg --enable-cli --disable-fpm --disable-embed --disable-micro --enable-pcntl --enable-zstd --with-libzstd="/home/www/build/buildroot" CFLAGS='' CPPFLAGS='-I/home/www/build/buildroot/include' LDFLAGS='-L/home/www/build/buildroot/lib' LIBS='-ldl -lpthread -lm'
[14:55:02] [INFO] cleaning up
[14:55:02] [INFO] Entering dir: /home/www/build/source/php-src
[14:55:02] [INFO] [EXEC] make clean
[14:55:03] [INFO] building cli
[14:55:03] [INFO] Entering dir: /home/www/build/source/php-src
[14:55:03] [INFO] [EXEC] sed -i "s|//lib|/lib|g" Makefile
[14:55:03] [INFO] [EXEC] $SPC_CMD_PREFIX_PHP_MAKE EXTRA_CFLAGS='-g -Os -fno-ident -fPIE' EXTRA_LIBS='/home/www/build/buildroot/lib/libzstd.a ' EXTRA_LDFLAGS_PROGRAM='-all-static' cli
[15:02:04] [INFO] Entering dir: /home/www/build/source/php-src/sapi/cli
[15:02:04] [INFO] [EXEC] strip --strip-all php
[15:02:04] [INFO] Deploying cli file
[15:02:04] [INFO] [EXEC] cp '/home/www/build/source/php-src/sapi/cli/php' '/home/www/build/buildroot/bin/'
[15:02:04] [INFO] running cli sanity check
[15:02:04] [INFO] [EXEC] /home/www/build/buildroot/bin/php -r "echo \"hello\";"
[15:02:04] [INFO] Build complete, used 554.717 s !
[15:02:04] [INFO] Static php binary path: /home/www/build/buildroot/bin/php
[15:02:04] [INFO] License path: /home/www/build/buildroot/license/
```
### 使用 PHP CLi
構建完成之后,會在當前目錄`buildroot/bin`生產一個二進制文件`php`,可以直接分發和使用。
```
buildroot/bin$ tree -L 1
.
├── php
├── pkg-config
├── unzstd -> zstd
├── zstd
├── zstdcat -> zstd
├── zstdgrep
├── zstdless
└── zstdmt -> zstd
```
查看PHP版本
```
/buildroot/bin$ ./php -v
PHP 8.2.22 (cli) (built: Aug 9 2024 23:01:57) (NTS)
Copyright (c) The PHP Group
Zend Engine v4.2.22, Copyright (c) Zend Technologies
```
已安裝模塊`pcntl,zstd`
```
./php -m
[PHP Modules]
Core
date
hash
json
pcntl
pcre
random
Reflection
SPL
standard
zstd
[Zend Modules]
```
打包編譯好的二進制文件
```
tar -czvf php-8.2.22-static-bin-x86_64.tar.gz /home/www/build/buildroot/bin/php
```
### 其他
#### 重復構建、調試
如果你需要重復構建、調試,你可以刪除`buildroot/`和`source/`兩個目錄,這樣你可以從已下載的源碼壓縮包重新解壓并構建:
```ts
# remove
rm -rf buildroot source
# build again
bin/spc build bcmath,curl,openssl,ftp,posix,pcntl --build-cli
```
#### 構建多個版本的 PHP
如果你想構建多個版本的 PHP,且不想每次都重復構建其他依賴庫,可以使用`switch-php-version`在編譯好一個版本后快速切換至另一個版本并編譯:
```ts
# switch to 8.3
bin/spc switch-php-version 8.3
# build
bin/spc build bcmath,curl,openssl,ftp,posix,pcntl --build-cli
# switch to 8.0
bin/spc switch-php-version 8.0
# build
bin/spc build bcmath,curl,openssl,ftp,posix,pcntl --build-cli
```
## 命令生成器
文檔:https://static-php.dev/zh/guide/cli-generator.html
- 設計模式系列
- 工廠方法模式
- 序言
- Windows程序注冊為服務的工具WinSW
- 基礎
- 安裝
- 開發規范
- 目錄結構
- 配置
- 快速入門
- 架構
- 請求流程
- 架構總覽
- URL訪問
- 容器和依賴注入
- 中間件
- 事件
- 代碼層結構
- 四個層次
- 路由
- 控制器
- 請求
- 響應
- 數據庫
- MySQL實時同步數據到ES解決方案
- 阿里云DTS數據MySQL同步至Elasticsearch實戰
- PHP中的MySQL連接池
- PHP異步非阻塞MySQL客戶端連接池
- 模型
- 視圖
- 注解
- @SpringBootApplication(exclude={DataSourceAutoConfiguration.calss})
- @EnableFeignClients(basePackages = "com.wotu.feign")
- @EnableAspectJAutoProxy
- @EnableDiscoveryClient
- 錯誤和日志
- 異常處理
- 日志處理
- 調試
- 驗證
- 驗證器
- 驗證規則
- 擴展庫
- 附錄
- Spring框架知識體系詳解
- Maven
- Maven和Composer
- 構建Maven項目
- 實操課程
- 01.初識SpringBoot
- 第1章 Java Web發展史與學習Java的方法
- 第2章 環境與常見問題踩坑
- 第3章 springboot的路由與控制器
- 02.Java編程思想深度理論知識
- 第1章 Java編程思想總體
- 第2章 英雄聯盟的小案例理解Java中最為抽象的概念
- 第3章 徹底理解IOC、DI與DIP
- 03.Spring與SpringBoot理論篇
- 第1章 Spring與SpringBoot導學
- 第2章 Spring IOC的核心機制:實例化與注入
- 第3章 SpringBoot基本配置原理
- 04.SprinBoot的條件注解與配置
- 第1章 conditonal 條件注解
- 第2章 SpringBoot自動裝配解析
- 05.Java異常深度剖析
- 第1章 Java異常分類剖析與自定義異常
- 第2章 自動配置Url前綴
- 06.參數校驗機制與LomBok工具集的使用
- 第1章 LomBok工具集的使用
- 第2章 參數校驗機制以及自定義校驗
- 07.項目分層設計與JPA技術
- 第1章 項目分層原則與層與層的松耦合原則
- 第2章 數據庫設計、實體關系與查詢方案探討
- 第3章 JPA的關聯關系與規則查詢
- 08.ORM的概念與思維
- 第1章 ORM的概念與思維
- 第2章 Banner等相關業務
- 第3章 再談數據庫設計技巧與VO層對象的技巧
- 09.JPA的多種查詢規則
- 第1章 DozerBeanMapper的使用
- 第2章 詳解SKU的規格設計
- 第3章 通用泛型Converter
- 10.令牌與權限
- 第1章 通用泛型類與java泛型的思考
- 常見問題
- 微服務
- demo
- PHP中Self、Static和parent的區別
- Swoole-Cli
- 為什么要使用現代化PHP框架?
- 公眾號
- 一鍵部署微信公眾號Markdown編輯器(支持適配和主題設計)
- Autodesigner 2.0發布
- Luya 一個現代化PHP開發框架
- PHPZip - 創建、讀取和管理 ZIP 文件的簡單庫
- 吊打Golang的PHP界天花板webman壓測對比
- 簡潔而強大的 YAML 解析庫
- 推薦一個革命性的PHP測試框架:Kahlan
- ServBay下一代Web開發環境
- 基于Websocket和Canvas實現多人協作實時共享白板
- Apipost預執行腳本如何調用外部PHP語言
- 認證和授權的安全令牌 Bearer Token
- Laradock PHP 的 Docker 完整本地開發環境
- 高效接口防抖策略,確保數據安全,避免重復提交的終極解決方案!
- TIOBE 6月榜單:PHP穩步前行,編程語言生態的微妙變化
- Aho-Corasick字符串匹配算法的實現
- Redis鍵空間通知 Keyspace Notification 事件訂閱
- ServBay如何啟用并運行Webman項目
- 使用mpdf實現導出pdf文件功能
- Medoo 輕量級PHP數據庫框架
- 在PHP中編寫和運行單元測試
- 9 PHP運行時基準性能測試
- QR碼生成器在PHP中的源代碼
- 使用Gogs極易搭建的自助Git服務
- Gitea
- webman如何記錄SQL到日志?
- Sentry PHP: 實時監測并處理PHP應用程序中的錯誤
- Swoole v6 Alpha 版本已發布
- Proxypin
- Rust實現的Redis內存數據庫發布
- PHP 8.4.0 Alpha 1 測試版本發布
- 121
- Golang + Vue 開發的開源輕量 Linux 服務器運維管理面板
- 內網穿透 FRP VS Tailscale
- 新一代開源代碼托管平臺Gitea
- 微服務系列
- Nacos云原生配置中心介紹與使用
- 輕量級的開源高性能事件庫libevent
- 國密算法
- 國密算法(商用密碼)
- GmSSL 支持國密SM2/SM3/SM4/SM9/SSL 密碼工具箱
- GmSSL PHP 使用
- 數據庫
- SQLite數據庫的Web管理工具
- 阿里巴巴MySQL數據庫強制規范
- PHP
- PHP安全測試秘密武器 PHPGGC
- 使用declare(strict_types=1)來獲得更健壯的PHP代碼
- PHP中的魔術常量
- OSS 直傳阿里騰訊示例
- PHP源碼編譯安裝APCu擴展實現數據緩存
- BI性能DuckDB數據管理系統
- 為什么別人可以是架構師!而我卻不是?
- 密碼還在用 MD5 加鹽?不如試試 password_hash
- Elasticsearch 在電商領域的應用與實踐
- Cron 定時任務入門
- 如何動態設置定時任務!而不是寫死在Linux Crontab
- Elasticsearch的四種查詢方式,你知道多少?
- Meilisearch vs Elasticsearch
- OpenSearch vs Elasticsearch
- Emlog 輕量級開源博客及建站系統
- 現代化PHP原生協程引擎 PRipple
- 使用Zephir編寫C擴展將PHP源代碼編譯加密
- 如何將PHP源代碼編譯加密,同時保證代碼能正常的運行
- 為什么選擇Zephir給PHP編寫動態擴展庫?
- 使用 PHP + XlsWriter實現百萬級數據導入導出
- Rust編寫PHP擴展
- 阿里云盤開放平臺對接進行文件同步
- 如何構建自己的PHP靜態可執行文件
- IM后端架構
- RESTful設計方法和規范
- PHP編譯器BPC 7.3 發布,成功編譯ThinkPHP8
- 高性能的配置管理擴展 Yaconf
- PHP實現雪花算法庫 Snowflake
- PHP官方現代化核心加密庫Sodium
- pie
- 現代化、精簡、非阻塞PHP標準庫PSL
- PHP泛型和集合
- 手把手教你正確使用 Composer包管理
- JWT雙令牌認證實現無感Token自動續期
- 最先進PHP大模型深度學習庫TransformersPHP
- PHP如何啟用 FFI 擴展
- PHP超集語言PXP
- 低延遲雙向實時事件通信 Socket.IO
- PHP OOP中的繼承和多態
- 強大的現代PHP高級調試工具Kint
- PHP基金會
- 基于webman+vue3高質量中后臺框架SaiAdmin
- 開源免費的定時任務管理系統:Gocron
- 簡單強大OCR工具EasyOCR在PHP中使用
- PHP代碼抽象語法樹工具PHP AST Viewer
- MySQL數據庫管理工具PHPMyAdmin
- Rust編寫的一款高性能多人代碼編輯器Zed
- 超高性能PHP框架Workerman v5.0.0-beta.8 發布
- 高并發系列
- 入門介紹及安裝
- Lua腳本開發 Hello World
- 執行流程與階段詳解
- Nginx Lua API 接口開發
- Lua模塊開發
- OpenResty 高性能的正式原因
- 記一次查找 lua-resty-mysql 庫 insert_id 的 bug
- 包管理工具OPM和LuaRocks使用
- 異步非阻塞HTTP客戶端庫 lua-resty-http
- Nginx 內置綁定變量
- Redis協程網絡庫 lua-resty-redis
- 動態HTML渲染庫 lua-testy-template
- 單獨的
- StackBlitz在線開發環境
- AI
- 基礎概念
- 12312
- 基礎鏡像的坑
- 利用phpy實現 PHP 編寫 Vision Transformer (ViT) 模型
- 語義化版本 2.0.0