This directory contains information for deploying the benchmark on a range of cloud or self-hosted environments. While you can always use manual deployment, automated scripts exist for many scenarios.
Before forging ahead, you should determine if your primary interest is development or benchmarking. Once you know this, look at the 'Summary of Script Directories' section to figure out which directory has scripts relevant to your use case.
If your primary interest is development, e.g. adding or updating frameworks, you can use an environment with a single computer running the database, the load generation system, and the web framework. We provide scripts for configuring a Linux development environment using either Virtualbox or Amazon EC2, and are actively searching for help adding Windows.
If your primary interest is benchmarking, then you will need three computers (or virtual machines) networked together to fill the three benchmark roles of database server, load generation server, and web framework server. We provide a Vagrant script to setup a full benchmark-ready Linux environment in Amazon EC2.
If you wish to benchmark a framework on a non-Amazon cloud, e.g. Azure or Rackspace, or a framework that requires Windows OS or SQL server, there are some limited helper scripts available at the moment. We welcome any pull requests along these lines.
Please note: Running this software will make many modifications to software and settings, so it's recommended you either use a VM or hardware dedicated to this project.
Client (aka load generation) Server
- Runs the benchmark client
- Operating system: Ubuntu Server 14.04 LTS 64-bit.
Database server
- Hosts databases (e.g.
MySQL
,PostgreSQL
,MongoDB
,SQL Server
). - Operating system:
Ubuntu Server 14.04 LTS 64-bit
orWindows Server 2012 Datacenter 64-bit
App (aka web framework) Server
- Hosts the web frameworks under test
- Operating system:
Windows Server 2012 Datacenter 64-bit
orUbuntu Server 14.04 LTS 64-bit
Directory Name | Summary |
---|---|
azure | Scripts to help deploy onto Microsoft Azure |
common | Common-use scripts that could be used in many environments |
vagrant-common | The core directory for vagrant-based setups. Currently only supports deplconfiguring Linux-based environments |
vagrant-aws | Setup scripts for configuring Amazon such that you can use vagrant-development and vagrant-production . Also outlines Amazon-specific options, such as instance type, you can use with vagrant-development and vagrant-production |
vagrant-virtualbox | A readme defining all the Virtualbox-specific options you can use with vagrant-development and vagrant-production , such as amount of RAM per virtual machine |
vagrant-development | Sets up a development environment using a single Virtual Machine. Can use either Virtualbox (for a free, locally run virtual machine) or Amazon EC2 (for a $1/day remote virtual machine) |
vagrant-production | Sets up a 3-virtual machine environment in either Amazon or Virtualbox. If Amazon is used, this is intended to be an environment you could run an official TechEmpower round with. A 3-VM VirtualBox setup is mainly used to test-run in a free environment before launching into a paid environment |
Evaluation downloads
If you want to run the benchmark on Windows and/or SQL Server, you can download evaluation versions from Microsoft:
Prerequisites
Before you get started, there are a couple of steps you can take to make running the tests easier on yourself.
Since the tests can run for several hours, it helps to set everything up so that once the tests are running, you can leave the machines unattended and don't need to be around to enter ssh or sudo passwords.
- Enable passwordless SSH access to localhost (search Google for help, yielding references such as these: article 1 article 2 article 3)
- Enable passwordless sudo access (Google for help).
After this, clone our repository and run toolset/run-tests.py --help
for
detailed guidance. You can also refer to the Benchmark Suite Setup README file for more information.
Installation and Usage Details
If you choose to run TFB on your own computer, you will need to install
passwordless SSH to your load server
and your database server
from
your app server
. You will also need to enable passwordless sudo access
on all three servers. If you are only planning to use verify mode, then
all three servers can be the same computer, and you will need to ensure
you have passwordless sudo access to localhost
.
For all Linux framework tests, we use Ubuntu 14.04, so it is recommended you use this for development or use. Furthermore, the load server is Linux-only, even when testing Windows frameworks.
- Connect to the Windows server via Remote Desktop.
- Copy
installer-bootstrap.ps1
from "toolset/setup/windows" to the server (use CTRL-C and CTRL-V). - Copy your Linux client private key too.
- Right click on the installer script and select
Run with PowerShell
. - Press Enter to confirm.
- It will install git and then launch
installer.ps1
from the repository, which will install everything else. - The installation takes about 20 minutes.
- Then you have a working console: try
python
,git
,ssh
,curl
,node
etc. and verify that everything works + PowerShell goodies.
The client/database machine is still assumed to be a Linux box. You can install just the client software via
python toolset\run-tests.py -s server-private-ip -c client-private-ip -i "C:\Users\Administrator\Desktop\client.key" --install-software --install client --list-tests
but this step is not required if you already installed the Linux server and client as described above.
Now you can run tests:
python toolset\run-tests.py -s server-private-ip -c client-private-ip -i "C:\Users\Administrator\Desktop\client.key" --max-threads 2 --duration 30 --sleep 5 --name win --test aspnet --type all
-
Connect to the SQL Server host via Remote Desktop.
-
Run a
Command Prompt
as Administrator. -
Enter this command:
powershell -ExecutionPolicy Bypass -Command "iex (New-Object Net.WebClient).DownloadString('https://raw.github.com/TechEmpower/FrameworkBenchmarks/master/toolset/setup/sqlserver/setup-sqlserver-bootstrap.ps1')"
-
This will configure SQL Server, the Windows Firewall, and populate the database.
Now, when running run-tests.py
, just add -d <ip of SQL Server instance>
. This works for the (Windows Server-based) aspnet-sqlserver-raw
and aspnet-sqlserver-entityframework
tests.
The benchmark suite will work on physical or virtual servers that have local network connectivity between them and Internet access for software download.
In general, any private or public hosting can be used, following this procedure:
- Provision the instances (servers) according to the roles, operating system and additional software described in the deploment overview.
- Configure networking as needed.
- Set the Linux hosts for passwordless sudo as described in the instructions for dedicated hardware.
Specific provisioning instructions and/or scripts for particular hosting or cloud services providers are welcome!