Kevin Clark | d3cee02 | 2008-06-18 01:19:09 +0000 | [diff] [blame] | 1 | $:.unshift File.dirname(__FILE__) + '/../lib' |
| 2 | require 'thrift' |
| 3 | require 'thrift/server/nonblockingserver' |
| 4 | $:.unshift File.dirname(__FILE__) + "/gen-rb" |
| 5 | require 'BenchmarkService' |
| 6 | |
| 7 | class Client |
| 8 | def initialize(host, port, clients_per_process, calls_per_client) |
| 9 | @host = host |
| 10 | @port = port |
| 11 | @clients_per_process = clients_per_process |
| 12 | @calls_per_client = calls_per_client |
| 13 | end |
| 14 | |
| 15 | def run |
| 16 | @clients_per_process.times do |
| 17 | socket = Thrift::Socket.new(@host, @port) |
| 18 | transport = Thrift::FramedTransport.new(socket) |
| 19 | protocol = Thrift::BinaryProtocol.new(transport) |
| 20 | client = ThriftBenchmark::BenchmarkService::Client.new(protocol) |
| 21 | begin |
Kevin Clark | d271979 | 2008-06-18 01:19:37 +0000 | [diff] [blame] | 22 | start = Time.now |
Kevin Clark | d3cee02 | 2008-06-18 01:19:09 +0000 | [diff] [blame] | 23 | transport.open |
Kevin Clark | d271979 | 2008-06-18 01:19:37 +0000 | [diff] [blame] | 24 | Marshal.dump [:start, start], STDOUT |
Kevin Clark | d3cee02 | 2008-06-18 01:19:09 +0000 | [diff] [blame] | 25 | rescue |
| 26 | Marshal.dump [:connection_failure, Time.now], STDOUT |
| 27 | else |
Kevin Clark | d271979 | 2008-06-18 01:19:37 +0000 | [diff] [blame] | 28 | begin |
| 29 | @calls_per_client.times do |
| 30 | Marshal.dump [:call_start, Time.now], STDOUT |
| 31 | client.fibonacci(15) |
| 32 | Marshal.dump [:call_end, Time.now], STDOUT |
| 33 | end |
| 34 | transport.close |
| 35 | Marshal.dump [:end, Time.now], STDOUT |
| 36 | rescue Thrift::TransportException |
| 37 | Marshal.dump [:connection_error, Time.now], STDOUT |
Kevin Clark | d3cee02 | 2008-06-18 01:19:09 +0000 | [diff] [blame] | 38 | end |
Kevin Clark | d3cee02 | 2008-06-18 01:19:09 +0000 | [diff] [blame] | 39 | end |
| 40 | end |
| 41 | end |
| 42 | end |
| 43 | |
| 44 | host, port, clients_per_process, calls_per_client = ARGV |
| 45 | |
| 46 | Client.new(host, port.to_i, clients_per_process.to_i, calls_per_client.to_i).run |