#benchmark #benchmarks #performance #web-frameworks

weltermann17 dbe8045565 fixed db update to be compliant with the requirements 12 years ago
HttpListener 0315a9a6c8 Fixed merge conflict 12 years ago
Raw-wrk-files e6928f611b Added raw wrk files from both full runs. run-1 is full test suite, run-2 is Linux OS/DB only 12 years ago
aspnet 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
aspnet-stripped 0315a9a6c8 Fixed merge conflict 12 years ago
beego 0315a9a6c8 Fixed merge conflict 12 years ago
bottle 1cf60a4923 Fix for DB communication for bottle frameworks 12 years ago
cake 0315a9a6c8 Fixed merge conflict 12 years ago
compojure 0315a9a6c8 Fixed merge conflict 12 years ago
config ec65e58c00 Merged in PR501 12 years ago
cowboy adbf7391df Added 'skip' attribute in benchmark_config to specify a test to skip. Added back in cowboy and elli with this new attribute added. 12 years ago
cpoll_cppsp c75caa1fe6 Compiled resources from various tests 12 years ago
dancer 09706dcea4 Stopped Nginx access logging by dancer and web-simple 12 years ago
dart fa44c12586 Gitlab development branch merged with GitHub master 12 years ago
dart-start 7e07dcf03e Merging in commit b2aa179ed15238c0fa82515d300615fc3871b556 from lucassp 12 years ago
dart-stream fa44c12586 Gitlab development branch merged with GitHub master 12 years ago
django 0315a9a6c8 Fixed merge conflict 12 years ago
dropwizard 0315a9a6c8 Fixed merge conflict 12 years ago
elli adbf7391df Added 'skip' attribute in benchmark_config to specify a test to skip. Added back in cowboy and elli with this new attribute added. 12 years ago
express 0315a9a6c8 Fixed merge conflict 12 years ago
falcon 0c372823c8 Update benchmark_configs attributes for pypy platforms 12 years ago
falcore 873dde0f06 Refactor benchmark_configs 12 years ago
finagle 0315a9a6c8 Fixed merge conflict 12 years ago
flask 13e621ef5d Fixed flask's app.py to have DBHOSTNAME 12 years ago
gemini c5ff12e4f5 Accepted PR485 (php-senthot from pentatonicfunk) with minor changes to benchmark_config and setup.py 12 years ago
go 9770efc9db a debugging line from Haley in toolset/benchmark/benchmarker.py 12 years ago
grails 0315a9a6c8 Fixed merge conflict 12 years ago
grizzly-bm 6790eb4f9b + update grizzly* test: remove System.in.read() call 12 years ago
grizzly-jersey 6790eb4f9b + update grizzly* test: remove System.in.read() call 12 years ago
hapi 0315a9a6c8 Fixed merge conflict 12 years ago
http-kit 0315a9a6c8 Fixed merge conflict 12 years ago
jester 0315a9a6c8 Fixed merge conflict 12 years ago
kelp fc68db4fc2 Disabling Nginx access logging from kelp and mojolicious 12 years ago
lapis 09d2deda06 Merge branch 'master' of https://github.com/lucassp/FrameworkBenchmarks into development 12 years ago
lift-stateless 0315a9a6c8 Fixed merge conflict 12 years ago
luminus 0315a9a6c8 Fixed merge conflict 12 years ago
mojolicious fc68db4fc2 Disabling Nginx access logging from kelp and mojolicious 12 years ago
nancy fa44c12586 Gitlab development branch merged with GitHub master 12 years ago
netty 0315a9a6c8 Fixed merge conflict 12 years ago
nodejs 0315a9a6c8 Fixed merge conflict 12 years ago
onion 9770efc9db a debugging line from Haley in toolset/benchmark/benchmarker.py 12 years ago
openresty 0315a9a6c8 Fixed merge conflict 12 years ago
php 0315a9a6c8 Fixed merge conflict 12 years ago
php-codeigniter 0315a9a6c8 Fixed merge conflict 12 years ago
php-fuel bb791b3b2e Removed large php logs 12 years ago
php-kohana cfdf960846 Removed php-kohana logs 12 years ago
php-laravel 0315a9a6c8 Fixed merge conflict 12 years ago
php-lithium 0315a9a6c8 Fixed merge conflict 12 years ago
php-micromvc 0315a9a6c8 Fixed merge conflict 12 years ago
php-phalcon c75caa1fe6 Compiled resources from various tests 12 years ago
php-phalcon-micro c75caa1fe6 Compiled resources from various tests 12 years ago
php-phpixie 3176d098fe Possible fix for DB issues with PHPixie 12 years ago
php-senthot c5ff12e4f5 Accepted PR485 (php-senthot from pentatonicfunk) with minor changes to benchmark_config and setup.py 12 years ago
php-silex 06a29754b8 Resolved merge conflicts from pulling github repo 12 years ago
php-silex-orm ae8e5eaff9 Changed the name of the php-silex-orm test to be unique. Was named identical to the php-silex default test 12 years ago
php-silica c75caa1fe6 Compiled resources from various tests 12 years ago
php-slim 0315a9a6c8 Fixed merge conflict 12 years ago
php-symfony2 06a29754b8 Resolved merge conflicts from pulling github repo 12 years ago
php-symfony2-stripped e53303c0de Updated PR500 benchmark_config with a unique framework name 12 years ago
php-yaf 0315a9a6c8 Fixed merge conflict 12 years ago
phreeze 0315a9a6c8 Fixed merge conflict 12 years ago
plack b87567463c Completed code and initial testing for batch resumption 12 years ago
plain dbe8045565 fixed db update to be compliant with the requirements 12 years ago
play-activate-mysql 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
play-java 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
play-java-jpa a449f08d94 Fixing play-java-jpa benchmark_config 12 years ago
play-scala 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
play-scala-mongodb 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
play-slick 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
play1 0315a9a6c8 Fixed merge conflict 12 years ago
play1siena 07b40b3c37 Updated aspnet-mvc metadata and consolidated play frameworks to play1 or play2 12 years ago
rack ad6ee87c08 Fixed rack-ruby, rack-jruby, rails-jruby by adding additional gems to Gemfiles. Fixed benchmarker.py by adding self to class method argument list 12 years ago
racket-ws 2a0aacbb38 Refactor benchmark_configs 12 years ago
rails c75caa1fe6 Compiled resources from various tests 12 years ago
rails-stripped ca66146d0b Updated rails-stripped gemfile with additional gems, both tests run. Fixed the OSError with servicestack-xsp-*, but all 3 tests get cannot to host errors still. 12 years ago
restexpress 0315a9a6c8 Fixed merge conflict 12 years ago
results fbd1a20f27 Added vertx results 12 years ago
revel b87567463c Completed code and initial testing for batch resumption 12 years ago
revel-jet b87567463c Completed code and initial testing for batch resumption 12 years ago
revel-qbs b87567463c Completed code and initial testing for batch resumption 12 years ago
ringojs 40c1605e47 fix platform for ringo frameworks 12 years ago
ringojs-convenient 6aad04fc08 Update benchmark_config 12 years ago
sbt 073afc2387 Add Windows support for Scala & Java frameworks 12 years ago
scalatra 0315a9a6c8 Fixed merge conflict 12 years ago
servicestack f340060bdf Removing forgotten tag from previous merge conflict 12 years ago
servlet 0315a9a6c8 Fixed merge conflict 12 years ago
sinatra 2e10876a50 Sinatra gemfiles updated similar to rails/rack, now runs fine 12 years ago
snap 0315a9a6c8 Fixed merge conflict 12 years ago
spark 0315a9a6c8 Fixed merge conflict 12 years ago
spray 0315a9a6c8 Fixed merge conflict 12 years ago
spring 0315a9a6c8 Fixed merge conflict 12 years ago
tapestry 0315a9a6c8 Fixed merge conflict 12 years ago
toolset 352089bebe Minor tweak on benchmarker.py for Windows use 12 years ago
tornado 0c372823c8 Update benchmark_configs attributes for pypy platforms 12 years ago
treefrog 0315a9a6c8 Fixed merge conflict 12 years ago
undertow fdb6885e82 Undertow fixes: postgresql version now running 12 years ago
unfiltered 0315a9a6c8 Fixed merge conflict 12 years ago
uwsgi 68cd905f5a Merge branch 'master' into uwsgi_perf 12 years ago
vertx 32f76eab91 Corrected content type for plaintext test. 12 years ago
wai 0315a9a6c8 Fixed merge conflict 12 years ago
web-simple 09706dcea4 Stopped Nginx access logging by dancer and web-simple 12 years ago
webgo d483576046 webgo: switch off date/time formatting 12 years ago
wicket 0315a9a6c8 Fixed merge conflict 12 years ago
wsgi 8fb77456fb Merge branch 'uwsgi_perf' of https://github.com/MalcolmEvershed/FrameworkBenchmarks into pr479_MalcomEvershed_uwsgi_wsgi_bottle_flask_20131003-1 12 years ago
yesod 0315a9a6c8 Fixed merge conflict 12 years ago
.gitignore d8cd457559 Added logs created by php-kohana and php-fuel to .gitignore 12 years ago
LICENSE 4b43363ad7 Added license 12 years ago
README.md a905a89a00 Revised benchmark_config documentation 12 years ago

README.md

Web Framework Performance Comparison

This project provides representative performance measures across a wide field of web application frameworks. With much help from the community, coverage is quite broad and we are happy to broaden it further with contributions. The project presently includes frameworks on many languages including Go, Python, Java, Ruby, PHP, Clojure, Groovy, JavaScript, Erlang, Haskell, Scala, Lua, and C. The current tests exercise plaintext responses, JSON seralization, database reads and writes via the object-relational mapper (ORM), collections, sorting, server-side templates, and XSS counter-measures. Future tests will exercise other components and greater computation.

Read more and see the results of our tests on Amazon EC2 and physical hardware at http://www.techempower.com/benchmarks/

Join in the conversation at our Google Group: https://groups.google.com/forum/?fromgroups=#!forum/framework-benchmarks

Running the test suite

We ran our tests using two dedicated i7 2600k machines as well as two EC2 m1.large instances.

On the Benchmark Tools README file you will find tools and instructions to replicate our tests using EC2, Windows Azure or your own dedicated machines.

Updating Tests

We hope that the community will help us in making these tests better, so if you'd like to make any changes to the tests we currently have, here are some things to keep in mind.

Updating Dependencies

If you're updating a dependency of a framework that uses a dependency management system (Bundler, npm, etc.), please be specific with the version number that you are updating to.

Also, if you do change the dependency of any test, please update the README file for that test to reflect that change, we want to try and keep the README files as up to date as possible.

Updating Software

If you would like to update any of the software used, again, please be as specific as possible, while we still install some software via apt-get and don't specify a version, we would like to have as much control over the versions as possible.

The main file that installs all the software is in toolset/setup/linux/installer.py. It's broken up into two sections, server software and client software.

Additionally, it may be necessary to update the setup.py file in the framework's directory to use this new version.

If you update any software, please update the README files of any tests that use that software.

Adding Frameworks

When adding a new framework or new test to an existing framework, please follow these steps:

  • Update/add benchmark_config
  • Update/add setup file
  • When creating a database test, please use the MySQL table hello_world.World, or the MongoDB collection hello_world.world

The Tests

For descriptions of the test types that we run against each framework, see the test requirements section of the Results web site.

The benchmark_config File

The benchmark_config file is used by our scripts to both identify the available tests and to extract metadata describing each test.

This file should exist at the root of the test directory.

Here is the basic structure of benchmark_config, using the Compojure framework as an example. Compojure has two test permutations, which are identified as the "tests" list in the JSON structure below.

{
  "framework": "compojure",
  "tests": [{
    "default": {
      "setup_file": "setup",
      "json_url": "/compojure/json",
      "db_url": "/compojure/db/1",
      "query_url": "/compojure/db/",
      "fortune_url": "/compojure/fortune-hiccup",
      "plaintext_url": "/compojure/plaintext",
      "port": 8080,
      "approach": "Realistic",
      "classification": "Micro",
      "database": "MySQL",
      "framework": "compojure",
      "language": "Clojure",
      "orm": "Micro",
      "platform": "Servlet",
      "webserver": "Resin",
      "os": "Linux",
      "database_os": "Linux",
      "display_name": "compojure",
      "notes": "",
      "versus": "servlet"
    },
    "raw": {
      "setup_file": "setup",
      "db_url": "/compojure/dbraw/1",
      "query_url": "/compojure/dbraw/",
      "port": 8080,
      "approach": "Realistic",
      "classification": "Micro",
      "database": "MySQL",
      "framework": "compojure",
      "language": "Clojure",
      "orm": "Raw",
      "platform": "Servlet",
      "webserver": "Resin",
      "os": "Linux",
      "database_os": "Linux",
      "display_name": "compojure-raw",
      "notes": "",
      "versus": "servlet"
    }
  }]
}
  • framework: Specifies the framework name.
  • tests: An list of tests that can be run for this framework. In many cases, this contains a single element for the "default" test, but additional tests can be specified. Each test name must be unique when concatenated with the framework name.
    • setup_file: The location of the setup file that can start and stop the test. By convention this is just setup.py.
    • json_url (optional): The URI to the JSON test, typically /json
    • db_url (optional): The URI to the database test, typically /db
    • query_url (optional): The URI to the variable query test. The URI must be set up so that an integer can be applied to the end of the URI to specify the number of queries to run. For example, "/query?queries=" (to yield /query?queries=20" or "/query/" to yield "/query/20".
    • fortune_url (optional): the URI to the fortunes test, typically /fortune
    • update_url (optional): the URI to the updates test, setup in a manner similar to the query_url described above.
    • plaintext_url (optional): the URI of the plaintext test, typically /plaintext
    • port: The port the server is listening on
    • approach (metadata): Realistic or Stripped (see results web site for description of all metadata attributes)
    • classification (metadata): Full, Micro, or Platform
    • database (metadata): MySQL, Postgres, MongoDB, SQLServer, or None
    • framework (metadata): name of the framework
    • language (metadata): name of the language
    • orm (metadata): Full, Micro, or Raw
    • platform (metadata): name of the platform
    • webserver (metadata): name of the web-server (also referred to as the "front-end server")
    • os (metadata): The application server's operating system, Linux or Windows
    • database_os (metadata): The database server's operating system, Linux or Windows
    • display_name (metadata): How to render this test permutation's name in the results web site. Some permutation names can be really long, so the display_name is provided in order to provide something more succinct.
    • versus (optional): The name of another test (elsewhere in this project) that is a subset of this framework. This allows for the generation of the framework efficiency chart in the results web site. For example, Compojure is compared to "servlet" since Compojure is built on the Servlets platform.

Setup Files

The setup file is responsible for starting and stopping the test. This script is responsible for (among other things):

  • Modifying the framework's configuration to point to the correct database host
  • Compiling and/or packaging the code
  • Starting the server
  • Stopping the server

The setup file is a python script that contains a start() and a stop() function. The start function should build the source, make any necessary changes to the framework's configuration, and then start the server. The stop function should shutdown the server, including all sub-processes as applicable.

Configuring database connectivity in start()

By convention, the configuration files used by a framework should specify the database server as localhost so that developing tests in a single-machine environment can be done in an ad hoc fashion, without using the benchmark scripts.

When running a benchmark script, the script needs to modify each framework's configuration so that the framework connects to a database host provided as a command line argument. In order to do this, use setup_util.replace_text() to make necessary modifications prior to starting the server.

For example:

setup_util.replace_text("wicket/src/main/webapp/WEB-INF/resin-web.xml", "mysql:\/\/.*:3306", "mysql://" + args.database_host + ":3306")

Using localhost in the raw configuration file is not a requirement as long as the replace_text call properly injects the database host provided to the benchmarker toolset as a command line argument.

A full example

Here is an example of Wicket's setup file.

import subprocess
import sys
import setup_util

##################################################
# start(args)
#
# Starts the server for Wicket
# returns 0 if everything completes, 1 otherwise
##################################################
def start(args):

# setting the database url
setup_util.replace_text("wicket/src/main/webapp/WEB-INF/resin-web.xml", "mysql:\/\/.*:3306", "mysql://" + args.database_host + ":3306")

# 1. Compile and package
# 2. Clean out possible old tests
# 3. Copy package to Resin's webapp directory
# 4. Start resin
try:
  subprocess.check_call("mvn clean compile war:war", shell=True, cwd="wicket")
  subprocess.check_call("rm -rf $RESIN_HOME/webapps/*", shell=True)
  subprocess.check_call("cp wicket/target/hellowicket-1.0-SNAPSHOT.war $RESIN_HOME/webapps/wicket.war", shell=True)
  subprocess.check_call("$RESIN_HOME/bin/resinctl start", shell=True)
  return 0
except subprocess.CalledProcessError:
  return 1

##################################################
# stop()
#
# Stops the server for Wicket
# returns 0 if everything completes, 1 otherwise
##################################################
def stop():
try:
  subprocess.check_call("$RESIN_HOME/bin/resinctl shutdown", shell=True)
  return 0
except subprocess.CalledProcessError:
  return 1