Bu doküman, PHP'yi dinamik bir kütüphane olarak yükleyecek bir FrankenPHP yapısının nasıl oluşturulacağını açıklamaktadır. Önerilen yöntem bu şekildedir.
Alternatif olarak, statik yapılar oluşturma da mümkündür.
FrankenPHP, PHP 8.2 ve üstü ile uyumludur.
İlk olarak, PHP'nin kaynaklarını edinin ve bunları çıkarın:
tar xf php-*
cd php-*/Ardından, PHP'yi platformunuz için yapılandırın.
Bu şekilde yapılandırma gereklidir, ancak başka opsiyonlar da ekleyebilirsiniz (örn. ekstra uzantılar) İhtiyaç halinde.
./configure \
--enable-embed \
--enable-zts \
--disable-zend-signals \
--enable-zend-max-execution-timersYüklemek için Homebrew paket yöneticisini kullanın
libiconv, bison, re2c ve pkg-config:
brew install libiconv bison re2c pkg-config
echo 'export PATH="/opt/homebrew/opt/bison/bin:$PATH"' >> ~/.zshrcArdından yapılandırma betiğini çalıştırın:
./configure \
--enable-embed=static \
--enable-zts \
--disable-zend-signals \
--disable-opcache-jit \
--enable-static \
--enable-shared=no \
--with-iconv=/opt/homebrew/opt/libiconv/Son olarak, PHP'yi derleyin ve kurun:
make -j"$(getconf _NPROCESSORS_ONLN)"
sudo make installFrankenPHP'nin bazı özellikleri, yüklenmesi gereken isteğe bağlı bağımlılıklara ihtiyaç duyar. Bu özellikler, Go derleyicisine derleme etiketleri geçirilerek de devre dışı bırakılabilir.
| Özellik | Bağımlılık | Devre dışı bırakmak için derleme etiketi |
|---|---|---|
| Brotli sıkıştırma | Brotli | nobrotli |
| Dosya değişikliğinde işçileri yeniden başlatma | Watcher C | nowatcher |
Artık Go kütüphanesini kullanabilir ve Caddy yapımızı derleyebilirsiniz:
curl -L https://github.com/dunglas/frankenphp/archive/refs/heads/main.tar.gz | tar xz
cd frankenphp-main
./install_dependencies.sh
cd caddy/frankenphp
CGO_CFLAGS="$(php-config --includes) -I$PWD/../../dist/dependencies/include" \
CGO_LDFLAGS="$(php-config --ldflags) $(php-config --libs) -L$PWD/../../dist/dependencies/lib" \
go build -tags=nobadger,nomysql,nopgxBu, Mercure veya Vulcain olmadan bir frankenphp ikili dosyası oluşturacaktır. Üretim kullanımı için xcaddy kullanmak daha iyidir.
Alternatif olarak, FrankenPHP'yi özel Caddy modülleri ile derlemek için xcaddy kullanın:
CGO_ENABLED=1 \
XCADDY_GO_BUILD_FLAGS="-ldflags='-w -s' -tags=nobadger,nomysql,nopgx" \
CGO_CFLAGS="$(php-config --includes) -I$PWD/../../dist/dependencies/include" \
CGO_LDFLAGS="$(php-config --ldflags) $(php-config --libs) -L$PWD/../../dist/dependencies/lib" \
xcaddy build \
--output frankenphp \
--with github.com/dunglas/frankenphp/caddy \
--with github.com/dunglas/mercure/caddy \
--with github.com/dunglas/vulcain/caddy \
--with github.com/dunglas/caddy-cbrotli
# Add extra Caddy modules hereTip
Eğer musl libc (Alpine Linux'ta varsayılan) ve Symfony kullanıyorsanız,
varsayılan yığın boyutunu artırmanız gerekebilir.
Aksi takdirde, şu tarz hatalar alabilirsiniz PHP Fatal error: Maximum call stack size of 83360 bytes reached during compilation. Try splitting expression
Bunu yapmak için, XCADDY_GO_BUILD_FLAGS ortam değişkenini bu şekilde değiştirin
XCADDY_GO_BUILD_FLAGS=$'-ldflags "-w -s -extldflags \'-Wl,-z,stack-size=0x80000\'"'
(yığın boyutunun değerini uygulamanızın ihtiyaçlarına göre değiştirin).
Daha fazla bilgi için build-static.sh dosyasını kontrol edin.