Drill is a HTTP load testing application written in Rust inspired by Ansible syntax
Clone or download
Failed to load latest commit information.
example More docs Mar 6, 2018
src New defaults Mar 10, 2018
.gitignore Add cookie support Feb 25, 2018
Cargo.toml Release 0.3.5 Mar 1, 2018
LICENSE Initial commit May 18, 2017
README.md New syntax documentation Mar 10, 2018
SYNTAX.md New syntax documentation Mar 10, 2018



Drill is a HTTP load testing application written in Rust. The main goal for this project is to build a really lightweight tool as alternative to other that require JVM and other stuff.

You can write brenchmark files, in YAML format, describing all the stuff you want to test.

It was inspired by Ansible syntax because it is really easy to use and extend.

Here is an example for benchmark.yml:


threads: 4
base: 'http://localhost:9000'
iterations: 5

  - name: Include comments
    include: comments.yml

  - name: Fetch users
      url: /api/users.json

  - name: Fetch organizations
      url: /api/organizations

  - name: Fetch account
      url: /api/account
    assign: foo

  - name: Fetch manager user
      url: /api/users/{{ foo.manager_id }}

  - name: Assign values
      key: bar
      value: "2"

  - name: Fetch user from assign
      url: /api/users/{{ bar }}

  - name: Fetch some users
      url: /api/users/{{ item }}
      - 70
      - 73
      - 75

  - name: Fetch some users by hash
      url: /api/users/{{ item.id }}
      - { id: 70 }
      - { id: 73 }
      - { id: 75 }

  - name: Fetch some users from CSV
      url: /api/users/contacts/{{ item.id }}
    with_items_from_csv: ./fixtures/users.csv

  - name: Fetch no relative url
      url: http://localhost:9000/api/users.json

  - name: Support for POST method
      url: /api/users
      method: POST
      body: foo=bar&arg={{ bar }}

  - name: Login user
      url: /login?user=example&password=3x4mpl3

  - name: Fetch counter
      url: /counter
    assign: memory

  - name: Fetch counter
      url: /counter
    assign: memory

  - name: Fetch endpoint
      url: /?counter={{ memory.counter }}

  - name: Reset counter
      method: DELETE
      url: /

  - name: Custom headers
      url: /admin
        Authorization: Basic aHR0cHdhdGNoOmY=
        X-Foo: Bar

As you can see, you can play with interpolations in different ways. This will let you specify a benchmank with different requests and dependencies between them.

If you want to know more about the benchmank file syntax, read this


The easiest way right now is to install with cargo:

cargo install drill
drill --benchmark benchmark.yml --stats

or download the source code and compile it:

git clone git@github.com:fcsonline/drill.git && cd drill
cargo build --release
./target/release/drill --benchmark benchmark.yml --stats




This is the list of all features supported by the current version of drill:

  • Multi thread: run your benchmarks setting as many concurrent threads as you want.
  • Multi iterations: specify the number of iterations you want to run the benchmark.
  • Dynamic urls: execute requests with dynamic interpolations in the url, like /api/users/{{ item }}
  • Dynamic headers: execute requests with dynamic headers. Example: headers.yml
  • Request dependencies: create dependencies between requests with assign and url interpolations.
  • Split files: organize your benchmarks in multiple files and include them.
  • CSV support: read CSV files and build N requests fill dynamic interpolations with CSV data.
  • HTTP methods: build request with different http methods like GET, POST, PUT, PATCH or DELETE.
  • Cookie support: create benchmarks with sessions because cookies are propagates between requests.
  • Stats: get nice statistics about all the requests. Example: cookies.yml
  • Thresholds: compare the current benchmark performance against a stored one session and fail if a threshold is exceeded.

Test it

Go to the example directorty and you'll find a README how to test it in a safe environment.

Disclaimer: We really recommend not to run intensive benchmanks against production environments.

Command line interface

Full list of cli options, which is available under drill --help

drill 0.3.5
HTTP load testing application written in Rust inspired by Ansible syntax

    drill [OPTIONS] --benchmark <benchmark>

    -h, --help       Prints help information
    -s, --stats      Shows request statistics
    -V, --version    Prints version information

    -b, --benchmark <benchmark>    Sets the benchmark file
    -c, --compare <compare>        Sets a compare file
    -r, --report <report>          Sets a report file
    -t, --threshold <threshold>    Sets a threshold value in ms amongst the compared file


  • Complete and improve the interpolation engine
  • Add writing to a file support


This project started as a side project to learn Rust, so I'm sure that is full of mistakes and areas to be improve. If you think you can tweak the code to make it better, I'll really appreaciate a pull request. ;)