PHPBrew
Read this in other languages: English, Português - BR, 日本語.
phpbrew builds and installs multiple version php(s) in your $HOME directory.
What phpbrew can do for you:
- Configure options are simplified into variants, no worries about the path anymore!
- Build php with different variants like PDO, mysql, sqlite, debug ...etc.
- Compile apache php module and separate them by different versions.
- Build and install php(s) in your home directory, so you don't need root permission.
- Switch versions very easily and is integrated with bash/zsh shell.
- Automatic feature detection.
- Install & enable php extensions into current environment with ease.
- Install multiple php into system-wide environment.
- Path detection optimization for HomeBrew and MacPorts.
Requirement
Please see Requirement before you get started. you need to install some development packages for building PHP.
Installation
Just download it:
curl -L -O https://github.com/phpbrew/phpbrew/releases/latest/download/phpbrew.phar
chmod +x phpbrew.phar
Then you can install it into your bin folder:
sudo mv phpbrew.phar /usr/local/bin/phpbrew
Be sure to have /usr/local/bin
in your $PATH
environment variable.
Setting up
Init a bash script for your shell environment:
$ phpbrew init
Add these lines to your .bashrc
or .zshrc
file:
[[ -e ~/.phpbrew/bashrc ]] && source ~/.phpbrew/bashrc
Setting up lookup prefix
You may setup your prefered default prefix for looking up libraries, available
options are macports
, homebrew
, debian
, ubuntu
or a custom path:
For Homebrew users:
$ phpbrew lookup-prefix homebrew
For Macports users:
$ phpbrew lookup-prefix macports
Basic usage
To list known versions:
$ phpbrew known
7.0: 7.0.3, 7.0.2, 7.0.1, 7.0.0 ...
5.6: 5.6.18, 5.6.17, 5.6.16, 5.6.15, 5.6.14, 5.6.13, 5.6.12, 5.6.11 ...
5.5: 5.5.32, 5.5.31, 5.5.30, 5.5.29, 5.5.28, 5.5.27, 5.5.26, 5.5.25 ...
5.4: 5.4.45, 5.4.44, 5.4.43, 5.4.42, 5.4.41, 5.4.40, 5.4.39, 5.4.38 ...
5.3: 5.3.29, 5.3.28 ...
To show more minor versions:
$ phpbrew known --more
To update the release info:
$ phpbrew update
To get older versions (less than 5.4)
Please note that we don't guarantee that you can build the php versions that are not supported by offical successfully, please don't fire any issue about the older versions, these issues won't be fixed.
$ phpbrew update --old
To list known older versions (less than 5.4)
$ phpbrew known --old
Starting Building Your Own PHP
Simply build and install PHP with default variant:
$ phpbrew install 5.4.0 +default
Here we suggest default
variant set, which includes most commonly used
variants, if you need a minimum install, just remove the default
variant set.
You can enable parallel compilation by passing -j
or --jobs
option and
the following is an example:
$ phpbrew install -j $(nproc) 5.4.0 +default
With tests:
$ phpbrew install --test 5.4.0
With debug messages:
$ phpbrew -d install --test 5.4.0
To install older versions (less than 5.3):
$ phpbrew install --old 5.2.13
To install the next (unstable) version:
$ phpbrew install next as php-7.1.0
To install from a github tag:
$ phpbrew install github:php/php-src@PHP-7.0 as php-7.0.0
Cleaning up build directory
$ phpbrew clean php-5.4.0
Variants
PHPBrew arranges configure options for you, you can simply specify variant name, and phpbrew will detect include paths and build options for configuring.
PHPBrew provides default variants and some virtual variants, to the default variants, which includes the most commonly used variants, to the virtual variants, which defines a variant set, you may use one virtual variant to enable multiple variants at one time.
To check out what is included in these variants, simply run variants
subcommand to list these variants:
$ phpbrew variants
Variants:
all, apxs2, bcmath, bz2, calendar, cgi, cli, ctype, dba, debug, dom, embed,
exif, fileinfo, filter, fpm, ftp, gcov, gd, gettext, hash, iconv, icu,
imap, intl, ipc, ipv6, json, kerberos, mbregex, mbstring, mcrypt, mhash,
mysql, openssl, pcntl, pcre, pdo, pgsql, phar, posix, readline, session,
soap, sockets, sqlite, tidy, tokenizer, xml_all, xmlrpc, zip, zlib, gmp
Virtual variants:
dbs: sqlite, mysql, pgsql, pdo
mb: mbstring, mbregex
neutral:
default: filter, dom, bcmath, ctype, mhash, fileinfo, pdo, posix, ipc,
pcntl, bz2, zip, cli, json, mbstring, mbregex, calendar, sockets, readline,
xml_all
Using variants to build PHP:
phpbrew install 5.3.10 +default
phpbrew install 5.3.10 +mysql +pdo
phpbrew install 5.3.10 +mysql +pdo +apxs2
phpbrew install 5.3.10 +mysql +pdo +apxs2=/usr/bin/apxs2
To enable one variant, simply add a prefix +
before the variant name, eg
+mysql
To disable one variant, simply add a prefix -
before the variant name.
-debug
For example, if we want to build PHP with the default options and database supports (mysql, sqlite, postgresql), you may simply run:
$ phpbrew install 5.4.5 +default+dbs
You may also build PHP with extra variants:
$ phpbrew install 5.3.10 +mysql+sqlite+cgi
$ phpbrew install 5.3.10 +mysql+debug+pgsql +apxs2
$ phpbrew install 5.3.10 +pdo +mysql +pgsql +apxs2=/usr/bin/apxs2
To build PHP with pgsql (PostgreSQL) extension:
$ phpbrew install 5.4.1 +pgsql+pdo
Or build pgsql extension with postgresql base dir on Mac OS X:
$ phpbrew install 5.4.1 +pdo+pgsql=/opt/local/lib/postgresql91/bin
The pgsql path is the location of pg_config
, you could find pg_config
in the /opt/local/lib/postgresql91/bin
To build PHP with neutral compile options, you can specify neutral
virtual variant, which means that phpbrew
doesn't add any additional compile options including --disable-all
. But some options(for example --enable-libxml
)
are still automatically added to support pear
installation.
You can build PHP with neutral
:
$ phpbrew install 5.4.1 +neutral
For more details, please check out PHPBrew Cookbook.
Extra Configure Options
To pass extra configure arguments, you can do this:
$ phpbrew install 5.3.10 +mysql +sqlite -- \
--enable-ftp --apxs2=/opt/local/apache2/bin/apxs
Use And Switch
Use (switch version temporarily):
$ phpbrew use 5.4.22
Switch PHP version (switch default version)
$ phpbrew switch 5.4.18
Turn Off:
$ phpbrew off
If you enable apache PHP modules, remember to comment out or remove the settings.
$ sudo vim /etc/httpd/conf/httpd.conf
# LoadModule php5_module /usr/lib/httpd/modules/libphp5.3.21.so
# LoadModule php5_module /usr/lib/httpd/modules/libphp5.3.20.so
List installed PHP
$ phpbrew list
The Extension Installer
You can also install PHP extension with ease, either the extensions shipped with PHP source code or even from PECL.
If the extension directory is found in PHP source, PHPBrew automatically switch into the PHP source directory and install the extension.
If the extension directory is not found in PHP source, PHPBrew fetch the extension package from PECL http://pecl.php.net.
PHPBrew also creates extension config to enable the installed extension, so you don't need to write the config file to enable it by hands. The extension config directory is in:
~/.phpbrew/php/php-{version}/var/db
Installing Extension - The Most Simple Way
Before you install any PHP extension, you should set your current running php:
$ phpbrew use php-5.5.6
Then run ext install
to install the extensions
$ phpbrew ext install apcu
$ phpbrew ext install memcache
Installing Extension With Stability
To install extensions with stability tag:
$ phpbrew ext install xdebug stable
$ phpbrew ext install xdebug latest
$ phpbrew ext install xdebug beta
To install extensions with version name:
$ phpbrew ext install xdebug 2.0.1
Showing extension config options
To see if there are some configure options to build the extension, you can use
the ext show
command. Please note that the show
command only works for
built-in extensions:
phpbrew ext show apcu
Install extensions with customized options:
$ phpbrew ext install yaml -- --with-yaml=/opt/local
Installing Extension from GitHub
The special prefix github:
tells phpbrew to get the extension repository from
php-memcached-dev/phpmemcached
and branch php7
$ phpbrew ext install github:php-memcached-dev/php-memcached php7 -- --disable-memcached-sasl
Installing Extension with specific downloader
Right now, phpbrew supports 4 different downloader implementation:
-
php_curl
- download files using the built-in php curl extension. -
php_stream
- download files using the built-in php stream wrapper. curl
wget
It's possible to replace the default downloader with your preference:
phpbrew ext install --downloader php_curl apcu
The curl php extension based downloader supports User-Agent and Proxy Settings, thus you can do this if you encountered some network issues:
phpbrew ext install --download php_curl --http-proxy=... --http-proxy-auth=... apcu
Enabling Extension
You can also install extension via PECL and enable it manually:
pecl install mongo
phpbrew ext enable mongo
The ext enable
command allows you to create a config {current php base}/var/db/{extension name}.ini
to enable the extension.
Configuring the php.ini for current php version
Simply run:
$ phpbrew config
You may specify the EDITOR environment variable to your favorite editor:
export EDITOR=vim
phpbrew config
Upgrade phpbrew
To upgrade phpbrew, you may simply run the self-update
command,
this command enables you to install the latest version of
master
branch from GitHub:
$ phpbrew self-update
The Installed PHP(s)
The installed phps are located in ~/.phpbrew/php
, for example, php 5.4.20 is located at:
~/.phpbrew/php/5.4.20/bin/php
And you should put your configuration file in:
~/.phpbrew/php/5.4.20/etc/php.ini
Extension configuration files should be put in:
~/.phpbrew/php/5.4.20/var/db
~/.phpbrew/php/5.4.20/var/db/xdebug.ini
~/.phpbrew/php/5.4.20/var/db/apc.ini
~/.phpbrew/php/5.4.20/var/db/memcache.ini
... etc
Quick commands to switch between directories
Switching to PHP build directory
$ phpbrew build-dir
Switching to PHP dist directory
$ phpbrew dist-dir
Switching to PHP etc directory
$ phpbrew etc-dir
Switching to PHP var directory
$ phpbrew var-dir
PHP FPM
phpbrew also provides useful fpm managing sub-commands. to use them, please
remember to enable +fpm
variant when building your own php.
To start php-fpm, simply type:
$ phpbrew fpm start
To stop php-fpm, type:
$ phpbrew fpm stop
To show php-fpm modules:
phpbrew fpm module
To test php-fpm config:
phpbrew fpm test
To edit php-fpm config:
phpbrew fpm config
The installed
php-fpm
is located in~/.phpbrew/php/php-*/sbin
.The correspond
php-fpm.conf
is lcoated in~/.phpbrew/php/php-*/etc/php-fpm.conf.default
, you may copy the default config file to the desired location. e.g.,cp -v ~/.phpbrew/php/php-*/etc/php-fpm.conf.default ~/.phpbrew/php/php-*/etc/php-fpm.conf php-fpm --php-ini {php config file} --fpm-config {fpm config file}
Enabling Version Info Prompt
To add PHP version info in your shell prompt, you can use
"PHPBREW_SET_PROMPT=1"
variable.
The default is "PHPBREW_SET_PROMPT=0"
(disable). To enable it, you can add this
line to your ~/.bashrc
file and put this line before you source
~/.phpbrew/bashrc
.
export PHPBREW_SET_PROMPT=1
To embed version info in your prompt, you can use
phpbrew_current_php_version
shell function, which is defined in .phpbrew/bashrc
.
and you can set the version info in your PS1
var.
e.g.
PS1=" \$(phpbrew_current_php_version) \$ "
Known Issues
For PHP-5.3+ versions, "Building intl 64-bit fails on OS X" https://bugs.php.net/bug.php?id=48795
-
To build PHP with GD extension, you need to specify your libpng dir and libjpeg dir, for example,
$ phpbrew install php-5.4.10 +default +mysql +intl +gettext +apxs2=/usr/bin/apxs2 \ -- --with-libdir=lib/x86_64-linux-gnu \ --with-gd=shared \ --enable-gd-natf \ --with-jpeg-dir=/usr \ --with-png-dir=/usr
Troubleshooting
Please see TroubleShooting
FAQ
Q: How do I have the same version with different compile option?
A: Currently, you can install php5.x.x and rename the /Users/phpbrew/.phpbrew/php/php-5.x.x folder to the new name, for example, php-5.x.x-super , and install another php-5.3.3
Contribution
Please see Contribution
Documentation
Please see Wiki
Author
- Yo-An Lin (c9s)
- Márcio Almad
License
See LICENSE file.