liquidm/z-http-request

View on GitHub
benchmarks/clients.rb

Summary

Maintainability
A
1 hr
Test Coverage
$: << './benchmarks'
require 'server'

require 'excon'
require 'httparty'
require 'net/http'
require 'open-uri'
require 'rest_client'
require 'tach'
require 'typhoeus'

url = 'http://127.0.0.1:9292/data/10000'

with_server do
  Tach.meter(100) do

    tach('curb (persistent)') do |n|
      curb = Curl::Easy.new

      n.times do
        curb.url = url
        curb.http_get
        curb.body_str
      end
    end

    tach('z-http-request') do |n|
      ZMachine.run {
        count = 0
        error = 0

        n.times do
          http = ZMachine::HttpRequest.new(url).get

          http.callback {
            count += 1
            if count == n
              p [count, error]
              ZMachine.stop
            end
          }

          http.errback {
            count += 1
            error += 1
            if count == n
              p [count, error]
              ZMachine.stop
            end
          }
        end
      }
    end

    tach('z-http-request (persistent)') do |n|
      ZMachine.run {
        count = 0
        error = 0

        conn = ZMachine::HttpRequest.new(url)

        n.times do
          http = conn.get :keepalive => true
          http.callback {
            count += 1
            if count == n
              p [count, error]
              ZMachine.stop
            end
          }

          http.errback {
            count += 1
            error += 1
            if count == n
              p [count, error]
              ZMachine.stop
            end
          }
        end
      }
    end

    tach('Excon') do
      Excon.get(url).body
    end

    excon = Excon.new(url)
    tach('Excon (persistent)') do
      excon.request(:method => 'get').body
    end

    tach('HTTParty') do
      HTTParty.get(url).body
    end

    uri = Addressable::URI.parse(url)
    tach('Net::HTTP') do
      Net::HTTP.start(uri.host, uri.port) {|http| http.get(uri.path).body }
    end

    uri = Addressable::URI.parse(url)
    Net::HTTP.start(uri.host, uri.port) do |http|
      tach('Net::HTTP (persistent)') do
        http.get(uri.path).body
      end
    end

    tach('open-uri') do
      open(url).read
    end

    tach('RestClient') do
      RestClient.get(url)
    end

    streamly = StreamlyFFI::Connection.new
    tach('StreamlyFFI (persistent)') do
      streamly.get(url)
    end

    tach('Typhoeus') do |n|
        hydra = Typhoeus::Hydra.new( max_concurrency: 8 )
        hydra.disable_memoization
        count = 0
        error = 0
        n.times {
            req = Typhoeus::Request.new( url )
            req.on_complete do |res|
                count += 1
                error += 1 if !res.success?
                p [count, error] if count == n

            end
            hydra.queue( req )
        }
        hydra.run
    end

  end
end


#+------------------------------+-----------+
#| tach                         | total     |
#+------------------------------+-----------+
#| z-http-request (persistent) | 0.145512  |
#+------------------------------+-----------+
#| Excon                        | 0.181564  |
#+------------------------------+-----------+
#| RestClient                   | 0.253127  |
#+------------------------------+-----------+
#| Net::HTTP                    | 0.294412  |
#+------------------------------+-----------+
#| HTTParty                     | 0.305397  |
#+------------------------------+-----------+
#| open-uri                     | 0.307007  |
#+------------------------------+-----------+
#| Net::HTTP (persistent)       | 0.313716  |
#+------------------------------+-----------+
#| Typhoeus                     | 0.514725  |
#+------------------------------+-----------+
#| curb (persistent)            | 3.981700  |
#+------------------------------+-----------+
#| StreamlyFFI (persistent)     | 3.989063  |
#+------------------------------+-----------+
#| Excon (persistent)           | 4.018761  |
#+------------------------------+-----------+
#| z-http-request              | 15.025291 |
#+------------------------------+-----------+