Installing ZendPHP on Debian and Ubuntu (DEB)
The preferred installation procedure for all Linux distributions and for IBM i is the zendphpctl tool. This article describes the alternative manual procedure for installing ZendPHP on Ubuntu or Debian using Debian software package files (DEB).
Set up repository on Debian/Ubuntu
Before installing ZendPHP for the first time, set up your repository:
-
Add the repos.zend.com GPG key to your apt keychain:
curl -s https://repos.zend.com/zend.key | gpg --dearmor > /usr/share/keyrings/zend.gpg
-
Add the repos.zend.com repository to your apt sources lists:
sudo echo "deb [signed-by=/usr/share/keyrings/zend.gpg] https://repos.zend.com/zendphp/deb_{os}{os_version}/ zendphp non-free" > /etc/apt/sources.list.d/zendphp.list
where {os} is one of "debian" or "ubuntu", and {os_version} is the operating system version, minus any "." separators (For example, for Ubuntu 20.04, it would be "2004", and the string would be "deb_ubuntu2004").
If you were provided credentials, provide the package manager with them:
$ sudo \ echo "machine repos.zend.com login {LOGIN_OR_ORDER_ID} password {PASSWORD}" \ > /etc/apt/auth.conf.d/zendphp.conf
-
Update your package sources:
sudo apt-get update
Install ZendPHP on Debian/Ubuntu
After setting up your repository and updating the packages, you can now install ZendPHP.
-
Install the PHP packages:
sudo apt-get install php{VERSION}-zend
This installs the common modules and the CLI binary for the specified version. If you would like to explore the additional packages that are available, use
sudo apt-cache search php{VERSION}-zend
to search our package library.We recommend installing the following packages in addition to the base package:
-
Switching PHP versions. You can switch between different PHP CLI binaries using the update-alternatives command:
sudo update-alternatives --set php /usr/bin/php{VERSION}-zend
-
[Optional] On Apache2, install the PHP package (representing
mod_php
) for your ZendPHP version:sudo apt-get install libapache2-mod-php{VERSION}-zend
This enables
mod_php
and configures it for use in handling PHP files. -
[Optional] To install FastCGI on Apache2, you need to install the
php-fpm
package for your PHP version:sudo apt-get install php{VERSION}-zend-fpm
Enable the FastCGI module and then configure the
php-fpm
bindings for it:sudo a2enmod proxy_fcgi setenvif sudo a2enconf php{VERSION}-zend-fpm
Start the
php-fpm
pool and Apache2:sudo systemctl start php{VERSION}-zend-fpm sudo systemctl restart apache2
Configuration for the pool is in
/etc/php/{VERSION}-zend/fpm/php-fpm.conf
. -
[Optional] To install FastCGI on nginx, you need to install the
php-fpm
package for your PHP version and nginx:sudo apt-get install php{VERSION}-zend-fpm nginx
From here, you need to create a virtual host configuration for nginx that proxies PHP requests to FastCGI as handled by your PHP version. For example on PHP 7.4 you need to edit the
/etc/nginx/sites-available/default
file to read:server { listen 80; root /var/www/html; server_name _; index index.html index.html index.php; location / { try_files $uri $uri/ /index.php$is_args$args; } location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/run/php/php7.4-zend-fpm.pid; } }
Now start the
php-fpm
pool and restart nginx:sudo systemctl start php{VERSION}-zend-fpm sudo systemctl restart nginx
Installing and using PECL on Debian/Ubuntu
The PECL binary, used to compile and install extensions shipped via https://pecl.php.net, is available via the php{VERSION}-zend-dev
package and requires the php{VERSION}-zend-xml
extension. You can install everything at once as follows:
sudo apt install -y php{VERSION}-zend-dev php{VERSION}-zend-xml
Installing an extension
Installing an extension via the PECL binary follows the generic instructions for all platforms:
sudo pecl install {extension_name}
Enabling an extension
Once compiled, you need to enable the extension. Generally, PECL provides information like the following on successful completion:
install ok: channel://pecl.php.net/extension-name-and-version configuration option "php_ini" is not set to php.ini location You should add "extension=extension-name.so" to php.ini
The important piece is the section contained in quotes in the last line. Copy that information and create a file named extensionname.ini
in /etc/php/{VERSION}-zend/mods-available/
as follows:
sudo echo "; configuration for php common module ; priority=20 extension=extension-name.so" > /etc/php/{VERSION}-zend/mods-available/extension-name.ini
Once done run php -m
(if using the CLI SAPI), or use phpinfo()
, to verify that your extension is enabled.