Mike Smith 2f0ad52bb3 Merge pull request #1869 from TechEmpower/silex-fix 9 年之前
..
cakephp ac5934005f Almost done... 10 年之前
clancats 0abeb33881 Merge branch 'master' into remove-install-scripts 10 年之前
codeigniter 0abeb33881 Merge branch 'master' into remove-install-scripts 10 年之前
cygnite-php-framework b47a396816 Merge pull request #1769 from sanjoydesk/master 10 年之前
fat-free 75c850c671 Fixed SOOOO many things 10 年之前
fuel ac5934005f Almost done... 10 年之前
hhvm cc8b629264 php/hhvm working with php7 9 年之前
kohana ac5934005f Almost done... 10 年之前
laravel 84294ae555 Fixed db error issues with laravel 9 年之前
limonade 2fd1d353be Merge branch 'master' into remove-install-scripts 10 年之前
lithium ac5934005f Almost done... 10 年之前
lumen 0abeb33881 Merge branch 'master' into remove-install-scripts 10 年之前
micromvc 75c850c671 Fixed SOOOO many things 10 年之前
phalcon 75c850c671 Fixed SOOOO many things 10 年之前
phalcon-micro 75c850c671 Fixed SOOOO many things 10 年之前
php 0d45c7ac61 Added php5 tests to php framework to compare with php7 9 年之前
phpixie 75c850c671 Fixed SOOOO many things 10 年之前
phreeze ac5934005f Almost done... 10 年之前
pimf 75c850c671 Fixed SOOOO many things 10 年之前
silex 216b242674 updated composer file and removed vendor files 9 年之前
silex-orm 75c850c671 Fixed SOOOO many things 10 年之前
slim 53c9928f81 Added php5 tests to php/slim framework to compare to php7 9 年之前
symfony2 0abeb33881 Merge branch 'master' into remove-install-scripts 10 年之前
symfony2-stripped ac5934005f Almost done... 10 年之前
yaf 75c850c671 Fixed SOOOO many things 10 年之前
yii2 b98effd7b0 Fixed framework error handling issues. Changed casing for Yii and AsyncIO 10 年之前
zend aa879670f1 Remove run-time warnings 10 年之前
zend1 92708462c5 Clean up warnings for zend1 10 年之前
README.md f86c9245be Move section 10 年之前

README.md

PHP Frameworks

The information below contains information specific to PHP. For further guidance, review the documentation.

Infrastructre Software Versions

PHP Version

Currently this toolset runs PHP 5.5.17. At the moment all PHP-based frameworks use the same PHP version, but we are open to receiving a pull request that enables supporting multiple versions.

Adding New PHP-based Frameworks

PHP Acceleration and Caching

Caching the output of the PHP bytecode compiler is expressly allowed by this benchmark. As we use PHP 5.5, which comes with opcache built in, we recommend you use this. However, some frameworks utilize APC instead as switching can be problematic (e.g. APC allows arbitrary data caching, while opcache).

Caching the output of parsing your configuration files is also expressly allowed (e.g. file caching, metadata caching). Some frameworks use APCu or memcached to achieve this.

Caching of the classloader (often referred to as optimizing the classloader) is also allowed. Most frameworks have their own methods of doing this.

Caching of any data fetched from the database is not allowed. Specifically, things such as Doctrine's Result Cache are inadmissible.

However, if you are using an ORM that prepares SQL statements in some way, such as how Doctrine translates DQL into SQL, this translated form can be cached, as long as you are dynamically accepting query parameters.

Caching any data using databases (Redis, MongoDB, etc) is discouraged, as 1) our databases run on a separate computer across the network, so you won't see much benefit 2) your usage of the DB may impact other framework's tests, which we cannot allow. You may launch a DB locally on the application server as part of your setup.sh scripts and utilize it for caching the allowable cache items, if you so desire, but it's normally much easier to use systems such as APCu.

Ask if you are not certain.

Install.sh and Setup.sh Files

Most PHP frameworks use fw_depends php nginx composer in their install.sh file, which installs PHP, Nginx, and Composer automatically. They then create a setup.sh containing these lines (comments added to clarify what's happening)

# Explanation of variables provided by toolset:
#   FWROOT - absolute path to framework toolset, normally 
#            something like /home/username/FrameworkBenchmarks
#   TROOT  - absolute path to this framework's folder, normally
#            something like /home/username/FrameworkBenchmarks/frameworks/PHP/cakephp
#   IROOT  - absolute path to the location where the toolset has installed software, 
#            something like /home/username/FrameworkBenchmarks/installs
#
# As of writing fw_depends installs 5.5.17 into the installer root
export PHP_HOME=${IROOT}/php-5.5.17
export PHP_FPM=$PHP_HOME/sbin/php-fpm
export NGINX_HOME=${IROOT}/nginx

# Uses the full path to php-fpm
#   - php-fpm configuration is located in the config folder found in the 
#     root of this project
#   - We tell PHP-FPM to place it's PID file into the deploy folder
$PHP_FPM --fpm-config $FWROOT/config/php-fpm.conf -g $TROOT/deploy/php-fpm.pid
# Turn on nginx using the configuration file found in this framework's deploy
# folder
$NGINX_HOME/sbin/nginx -c $TROOT/deploy/nginx.conf

When using php, php-fpm, or other binaries, always use the full path to the binary, e.g. instead of php <command>, use /home/foo/FrameworkBenchmarks/installs/php-5.5.17/bin/php <your command>.

Dependency Management Using Composer

Many PHP apps use Composer for dependency management, which greatly simplifies downloading the framework, loading the framework, and upgrading the framework version in the future.

There are two main guidelines for PHP frameworks:

  • Never include the source code for your framework into this repository. Download it using Composer, wget, or some other tool
  • When using Composer, always add a composer.lock file in addition to the composer.json file. The lock file is a fully-defined file generated by composer 1) reading your JSON file 2) finding all dependencies 3) downloading a lot of data from Github. Without this lock file, composer takes 2-3x longer to run, and it can even halt and require user input

Setting up Composer

Add a composer.json file to your framework's root folder, e.g. php-fuel/composer.json. Ensure your install.sh lists composer as a dependency, and uses composer.phar to install the dependencies required by your project.

# Note the order! Composer depends on PHP so it has to come second
fw_depends php composer 

# Download dependencies
${IROOT}/php-5.5.17/bin/php ${COMPOSER_HOME}/composer.phar install \
--no-interaction --working-dir $TROOT --no-progress \
--optimize-autoloader 

After installation runs, your framework folder will have a new vendor folder, e.g. php-fuel/vendor that contains all dependencies. Update your PHP scripts to either directly reference files inside of vendor, or use the vendor/autoload.php file.

Generating composer.lock file

Composer uses Github a lot, enough so that it is common for it to exceed the API limit and cause infinite hangs or installation failures. To avoid this, it is necessary to generate a composer.lock file. If you're lucky, you can run toolset/run-tests.py --install server --test <your framework> --install-only, which will run your install.sh file and leave the composer.lock file right next to your composer.json file. If this works, just add the lock file to the repository and you're done. There is more info on this here and here

Note: You may have to force-add the lock file (e.g. git add -f composer.lock), because some gitignore files in this repo contain *.lock to avoid Ruby's lock files.

If you are prompted for input during the run-tests.py script above, then you need to generate your lock file manually so that you may answer the input queries as they are shown. Use these steps

# Switch to the user that runs tests
sudo su testrunner

# Define the environment variables you need (modify as needed)
export IROOT=/home/you/FrameworkBenchmarks/installs
export TROOT=/home/you/FrameworkBenchmarks/frameworks/PHP/php-yii2

# Run the installation shown above
#
# This will manually prompt you for your Github credentials 
# to avoid the Github rate limit
# When this command completes, you will have a lock file 
${IROOT}/php-5.5.17/bin/php ${COMPOSER_HOME}/composer.phar install \
  --working-dir $TROOT

# Add the lock file to this repository
git add -f composer.lock

Updating Composer setup

If you update composer.json, you need to regenerate the lock file. If you forget to do this, you will see this error message when running:

Warning: The lock file is not up to date with the latest changes in composer.json. You may be getting outdated dependencies. Run update to update them.

Debugging PHP Frameworks

The first stop for HTTP 500 errors is to enable stack traces. Update config/php-fpm.conf to include php_flag[display_errors] = on. If you don't use php-fpm, update the config/php.ini

Get Help

PHP Experts

There aren't any PHP experts listed, yet. If you're an expert, add yourself!

Resources & Interesting Links

If you find some interesting links related to the PHP tests, add them here.