This is a build pack bundling PHP and Nginx for Heroku apps. Includes additional extensions: apc, memcache, memcached, phpredis, mcrypt, mysql, postgres, and newrelic. Dependency management is handled by Composer.
The config files are bundled:
- conf/nginx.conf.erb
- conf/etc.d/01_memcached.ini
- conf/etc.d/02_memcache.ini
- conf/etc.d/03_phpredis.ini
- conf/php.ini
- conf/php-fpm.conf
Create a conf/
directory in the root of the your deployment. Any files with names matching the above will be copied over and overwitten.
This way, you can customise settings specific to your application, especially the document root in nginx.conf.erb
. (Note the .erb extension.)
Edit support/set-env.sh
and bin/compile
to update the version numbers.
$ gem install vulcan
$ export AWS_ID="1BHAJK48DJFMQKZMNV93" # optional if s3 handled manually.
$ export AWS_SECRET="fj2jjchebsjksmMJCN387RHNjdnddNfi4jjhshh3" # as above
$ export S3_BUCKET="heroku-buildpack-php-ustramooner" # set to your S3 bucket.
$ source support/set-env.sh
Edit bin/compile
and support/ec2-build-php.sh
to reflect the correct S3 bucket.
Run:
$ support/package_nginx
The binary package will be produced in the current directory. Upload it to Amazon S3.
Run:
$ support/package_libmcrypt
The binary package will be produced in the current directory. Upload it to Amazon S3.
Run:
$ support/package_libmemcached
The binary package will be produced in the current directory. Upload it to Amazon S3.
Run:
$ support/package_newrelic
The binary package will be produced in the current directory. Upload it to Amazon S3.
PHP with mcrypt requires libmcrypt to be installed. Vulcan cannot be used to build in this case.
To pre-compile PHP for Heroku, spin up an Amazon EC2 instance within the US-East Region: ami-04c9306d
. Refer to support/ec2-up.sh
for some hints.
The use the following to compile PHP:
# after logging into EC2 instance, preferably with screen running.
$ curl -L "https://github.com/ustramooner/heroku-buildpack-php-tyler/raw/master/support/ec2-build-php.sh" -o - | sudo bash
You should review the build script at https://github.com/ustramooner/heroku-buildpack-php-tyler/blob/master/support/ec2-build-php.sh.
To speed up the slug compilation stage, precompiled binary packages are cached. The buildpack will attempt to fetch manifest.md5sum
to verify that the cached packages are still fresh.
This file is generated with the md5sum tool:
$ md5sum *.tar.gz > manifest.md5sum
Contents of manifest.md5sum
:
$ cat manifest.md5sum
7d99f732e54f6f53e026dd86de4158ac libmcrypt-2.5.8.tar.gz
1390676a5df6dc658fd9bce66eedae48 libmemcached-1.0.7.tar.gz
d2447fba1ff9f1dbdf86d3fb20c79c4c newrelic-2.9.5.78-heroku.tar.gz
9b861de30f67a66358d58a8f897f6262 nginx-1.2.2-heroku.tar.gz
ca9f712f2dde107f7a0ef44f0b743f1f php-5.4.4-with-fpm-heroku.tar.gz
Remember to upload an updated manifest.md5sum
to Amazon S3 whenever you upload new precompiled binary packages.
To make your changes, fork this repo first and replace the following URLs with yours.
Copy support/04_newrelic.ini.sample
to your heroku app as conf/etc.d/04_newrelic.ini
, and edit as necessary.
Export your new relic license key as the NEW_RELIC_LICENSE_KEY
env variable using heroku config
. This is already done for you if you have the New Relic add on enabled.
To use this buildpack, on a new Heroku app:
heroku create -s cedar -b git://github.com/ustramooner/heroku-buildpack-php-tyler.git
On an existing app:
heroku config:add BUILDPACK_URL=git://github.com/ustramooner/heroku-buildpack-php-tyler.git
heroku config:add PATH="/app/vendor/bin:/app/local/bin:/app/vendor/nginx/sbin:/app/vendor/php/bin:/app/vendor/php/sbin:/usr/local/bin:/usr/bin:/bin"
Push deploy your app and you should see Nginx, mcrypt, and PHP being bundled.
Composer is the de fecto dependency manager for PHP, similar to Bundler in Ruby.
- Declare your dependencies in
composer.json
; see docs for syntax and other details. - Run
php composer.phar install
locally at least once to generate acomposer.lock
file. Make sure this file is also committed into version control. - When you push the app, the buildpack will fetch and install dependencies when it detects both
composer.json
andcomposer.lock
files.
Note: It is optional to have composer.phar
within the application root. If missing, the buildpack will automatically fetch the latest version available from http://getcomposer.org/composer.phar.
Setup the test environment on Heroku as follows:
$ cd heroku-buildpack-php-tyler/
$ heroku create -s cedar -b git://github.com/ryanbrainard/heroku-buildpack-testrunner.git
Creating deep-thought-1234... done, stack is cedar
http://deep-thought-1234.herokuapp.com/ | git@heroku.com:deep-thought-1234.git
Git remote heroku added
Then, push the buildpack to be tested into Heroku:
$ git push -f heroku <branch>:master # where <branch> is the git branch you want to test.
Finally, run those tests:
$ heroku run tests
If you run your tests programatically, you might need the follow command instead:
$ heroku run tests | bin/report
Source: https://github.com/ryanbrainard/heroku-buildpack-testrunner
Updated for Nginx+PHP support with memcache, phpredis, and mcrypt support by Ronald Ip from https://github.com/heroku/heroku-buildpack-php.
Credits to original authors.