install php in os x
PHP 5.3/5.4/5.5 for
OS X 10.6/10.7/10.8/10.9
as binary package
Installation |
FAQ |
Additional important notes |
(Alternative) Installation by "hand" |
Included extensions |
Uninstall |
Source code |
Thanks |
Support |
Latest releases
Intro
This package installs the (usually) latest PHP 5.3.x/5.4.x/5.5.x on OS X 10.6 (aka Snow Leopard), OS X 10.7 (aka Lion) and OS X 10.8 (aka Mountain Lion) and OS X 10.9 (aka Mavericks) in /usr/local/php5. It installs many useful extensions (see below) and ini-settings and is what we at Liip and Local.ch use for our development. It's especially suited for Symfony 2 development. It also provides a decent php.ini with all settings configured according to "Best Practices".It doesn't install Apache, MySQL or any other external programs. It uses the Apache installation, which comes with OS X and for installing MySQL you can for example use Homebrew. The package is based on entropy's php package .
One Line Installation
All you need to do to install the whole thing is opening up a Shell and execute the following line:PHP 5.3
curl -s http://php-osx.liip.ch/install.sh | bash -s 5.3
PHP 5.4 (Old stable)
curl -s http://php-osx.liip.ch/install.sh | bash -s 5.4
PHP 5.5 (Current stable)
curl -s http://php-osx.liip.ch/install.sh | bash -s 5.5It will ask you for your password. We install the packager in /usr/local/packer and PHP into /usr/local/php5 and for this, we need your password. We don't do anything bad with it.
Frequently Asked Questions
Why does php -v on the command line still show my old version?
php-osx doesn't overwrite the php binaries installed by Apple, but installs everyting in /usr/local/php5. The new php binary is therefore in /usr/local/php5/bin/php.You can also adjust your PATH do include that directory, eg. write into your ~/.profile file the following
export PATH=/usr/local/php5/bin:$PATH
Why is Europe/Zurich the default timezone? Where to change that?
Because we are based in Zurich (and Fribourg and Lausanne). Change the file in /usr/local/php5/php.d/99-liip-developer.ini to adjust that.It doesn't take my php.ini values
We introduced our own ini file to be able to easily overwrite the standard values with our recommended values. You can find it in /usr/local/php5/php.d/99-liip-developer.iniAs this is read last, it will overwrite values defined in other files. You can also just delete the file.
Why is the MySQL Socket configured to use /tmp/mysql.sock and how to change that?
If you download the native binary from mysql.com, that server uses /tmp/mysql.sock as its socket location (see this). Therefore we choose that value as default.You can change that value in /usr/local/php5/php.d/99-liip-developer.ini
Where is the memcached daemon?
We started not including the memcached daemon anymore. But you can install it by hand withsudo /usr/local/packager/packager.py install tools-memcached
How can I help?
This project is hosted on github here https://github.com/liip/build-entropy-php/. The website itself and install.sh is hosted on https://github.com/liip/php-osx/. It's all Open Source, so feel free to fork it and send Pull Requests, if you want to change/fix something.I have more questions. Where to put them?
You have basically three options:- Open a ticket at https://github.com/liip/php-osx/issues
- Write a tweet, we monitor that and are reachable at @php_osx
- Write on Stack Overflow with the tags "php osx". We do monitor that, as well
Additional important notes
32 bit only systems (no workie)
It only works on a 64-bit-capable system. This means not on very old hardware with Intel Core Duo and Intel Core Solo processors (see http://support.apple.com/kb/ht3696 for the overview). If anyone wants to make it work on those systems too, please tell us how (We tried, but didn't came up with anything running in a decent amount of time)php.ini
The php.ini is located in /usr/local/php5/lib/php.ini, additional config files are located in /usr/local/php5/php.d/. The php.ini is based on php.ini-developmentLiip php.ini
The Liip php.ini for development is located in /usr/local/php5/php.d/99-liip-developer.ini.Re-installs into new directory
All installed files go in a new directory with every update, you have to manually maintain/merge your changes from the old directory! (like pear installs)apc, twig and xslcache
apc, twig and xslcache need to be enabled manually in /usr/local/php5/php.d/50-extension-$name.ini.xdebug
xdebug settings needs to be configured (idekey etc) manually in /usr/local/php5/php.d/50-extension-xdebug.ini.apache error with ulimit
If you are seeing "/usr/sbin/apachectl: line 82: ulimit: open files: cannot modify limit: Invalid argument" when loading apache, here is a fixMore history and all that
See this blog post for even more background info.(Alternative) Installation by "hand"
If you don't trust us, here's the code of install.sh, which you can run by yourself (instead of the one-liner above):curl -s -o /tmp/packager.tgz http://php-osx.liip.ch/packager/packager.tgz sudo tar -C /usr/local -xzf /tmp/packager.tgz sudo /usr/local/packager/packager.py install 5.4-frontenddevIf you already have installed the packager and just want to update the PHP package, you can do it with the following line.
sudo /usr/local/packager/packager.py install tools-frontenddev
Included extensions
bcmath bz2 calendar Core ctype curl date dom dtrace ereg exif fileinfo filter ftp gd gettext hash iconv imap intl json ldap libxml mbstring mcrypt memcache memcached mhash mongo mssql mysql mysqli mysqlnd OAuth odbc openssl pcntl pcre PDO pdo_dblib pdo_mysql pdo_pgsql pdo_sqlite pgsql Phar posix Reflection session shmop SimpleXML soap sockets solr SPL SQLite sqlite3 standard sysvmsg sysvsem sysvshm tidy tokenizer wddx xdebug xhprof xml xmlreader xmlrpc xmlwriter xsl zip zlib Xdebugavailable but disabled by default: apc, xslcache, twig, uploadprogress
See this output of phpinfo() for more info.
Uninstall
Change in /etc/apache2/httpd.confLoadModule php5_module /usr/local/php5/libphp5.so
toLoadModule php5_module libexec/apache2/libphp5.so
also delete the file +php-osx.conf and +entropy-php.conf in /etc/apache2/other
and optionally remove /usr/local/php5-*
Source Code
- build-entropy-php. Needed for generating the PHP binaries and all the needed libraries
- packager by local.ch. This downloads and install the package on your computer.
- php-osx. The scripts needed for doing the package and this webpage