From d4d8e8684c98a6e85e39e3c34f8f09425ca8f2a3 Mon Sep 17 00:00:00 2001 From: Wesley Beary Date: Mon, 31 Aug 2009 23:16:53 -0700 Subject: [PATCH] benchmarks --- benchs/fog_vs.rb | 67 +++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 63 insertions(+), 4 deletions(-) diff --git a/benchs/fog_vs.rb b/benchs/fog_vs.rb index 050e7c055..c522786da 100644 --- a/benchs/fog_vs.rb +++ b/benchs/fog_vs.rb @@ -1,14 +1,14 @@ require 'rubygems' +require 'aws/s3' require 'benchmark' require 'right_aws' -$LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib')) -require 'fog/aws' +require File.join(File.dirname(__FILE__), '..', 'lib', 'fog') -data = File.open(File.expand_path('~/.s3conf/s3config.yml')).read +data = File.open(File.join(File.dirname(__FILE__), '..', 'spec', 'credentials.yml')).read config = YAML.load(data) fog = Fog::AWS::S3.new( - :aws_access_key_id => config['aws_access_key_id'], + :aws_access_key_id => config['aws_access_key_id'], :aws_secret_access_key => config['aws_secret_access_key'] ) raws = RightAws::S3Interface.new( @@ -16,6 +16,11 @@ raws = RightAws::S3Interface.new( config['aws_secret_access_key'] ) raws.logger.level = 3 # ERROR +awss3 = AWS::S3::Base.establish_connection!( + :access_key_id => config['aws_access_key_id'], + :secret_access_key => config['aws_secret_access_key'], + :persistent => true +) TIMES = 10 @@ -30,6 +35,11 @@ Benchmark.bmbm(25) do |bench| raws.create_bucket("rawsbench#{x}") end end + bench.report('awss3::Bucket.create') do + TIMES.times do |x| + AWS::S3::Bucket.create("awss3bench#{x}") + end + end bench.report('fog.put_object') do TIMES.times do |x| @@ -47,6 +57,14 @@ Benchmark.bmbm(25) do |bench| end end end + bench.report('awss3::S3Object.create') do + TIMES.times do |x| + TIMES.times do |y| + file = File.open(File.dirname(__FILE__) + '/../spec/lorem.txt', 'r') + AWS::S3::S3Object.create("lorem_#{y}", file, "awss3bench#{x}") + end + end + end bench.report('fog.delete_object') do TIMES.times do |x| @@ -62,6 +80,13 @@ Benchmark.bmbm(25) do |bench| end end end + bench.report('awss3::S3Object.delete') do + TIMES.times do |x| + TIMES.times do |y| + AWS::S3::S3Object.delete("lorem_#{y}", "awss3bench#{x}") + end + end + end bench.report('fog.delete_bucket') do TIMES.times do |x| @@ -73,4 +98,38 @@ Benchmark.bmbm(25) do |bench| raws.delete_bucket("rawsbench#{x}") end end + bench.report('awss3::Bucket.delete') do + TIMES.times do |x| + AWS::S3::Bucket.delete("awss3bench#{x}") + end + end end + +# Rehearsal ------------------------------------------------------------ +# fog.put_bucket 0.010000 0.000000 0.010000 ( 4.981517) +# raws.create_bucket 0.030000 0.040000 0.070000 ( 10.035029) +# awss3::Bucket.create 0.020000 0.020000 0.040000 ( 7.402162) +# fog.put_object 0.080000 0.080000 0.160000 ( 8.757062) +# raws.put 0.180000 0.080000 0.260000 ( 12.307371) +# awss3::S3Object.create 0.170000 0.070000 0.240000 ( 14.028887) +# fog.delete_object 0.080000 0.050000 0.130000 ( 5.481744) +# raws.delete 0.140000 0.070000 0.210000 ( 7.709116) +# awss3::S3Object.delete 0.100000 0.040000 0.140000 ( 5.533884) +# fog.delete_bucket 0.010000 0.010000 0.020000 ( 1.861061) +# raws.delete_bucket 0.030000 0.020000 0.050000 ( 3.146836) +# awss3::Bucket.delete 0.050000 0.010000 0.060000 ( 1.877064) +# --------------------------------------------------- total: 1.390000sec +# +# user system total real +# fog.put_bucket 0.010000 0.020000 0.030000 ( 1.949933) +# raws.create_bucket 0.030000 0.020000 0.050000 ( 4.766058) +# awss3::Bucket.create 0.010000 0.010000 0.020000 ( 2.093764) +# fog.put_object 0.090000 0.080000 0.170000 ( 9.352868) +# raws.put 0.150000 0.080000 0.230000 ( 12.981112) +# awss3::S3Object.create 0.130000 0.070000 0.200000 ( 14.442972) +# fog.delete_object 0.060000 0.060000 0.120000 ( 5.657752) +# raws.delete 0.130000 0.050000 0.180000 ( 6.598221) +# awss3::S3Object.delete 0.110000 0.030000 0.140000 ( 5.709799) +# fog.delete_bucket 0.010000 0.010000 0.020000 ( 1.864573) +# raws.delete_bucket 0.040000 0.030000 0.070000 ( 4.120572) +# awss3::Bucket.delete 0.020000 0.000000 0.020000 ( 1.947711)