#benchmark #benchmarks #performance #web-frameworks

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

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