forked from TrueCloudLab/s3-tests
dho-qa: static file generator updated to use common
Updated generate_objects.py to use Wes's common setup and configuration stuff. Can still override config on the command line.
This commit is contained in:
parent
951dc0fcdb
commit
a4e5be5f41
1 changed files with 30 additions and 30 deletions
|
@ -6,12 +6,13 @@ from boto.s3.key import Key
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
from realistic import RandomContentFile
|
from realistic import RandomContentFile
|
||||||
import realistic
|
import realistic
|
||||||
|
import traceback
|
||||||
import random
|
import random
|
||||||
|
import common
|
||||||
import yaml
|
import yaml
|
||||||
import boto
|
import boto
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
DHO_HOST = 'objects.dreamhost.com'
|
|
||||||
|
|
||||||
def parse_opts():
|
def parse_opts():
|
||||||
parser = OptionParser();
|
parser = OptionParser();
|
||||||
|
@ -23,30 +24,9 @@ def parse_opts():
|
||||||
parser.add_option('--host', dest='host', help='use S3 gateway at HOST', metavar='HOST')
|
parser.add_option('--host', dest='host', help='use S3 gateway at HOST', metavar='HOST')
|
||||||
parser.add_option('--seed', dest='seed', help='optional seed for the random number generator')
|
parser.add_option('--seed', dest='seed', help='optional seed for the random number generator')
|
||||||
|
|
||||||
parser.set_defaults(host=DHO_HOST)
|
|
||||||
|
|
||||||
return parser.parse_args()
|
return parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
def parse_config(config_files):
|
|
||||||
configurations = []
|
|
||||||
for file in config_files:
|
|
||||||
FILE = open(file, 'r')
|
|
||||||
configurations = configurations + yaml.load(FILE.read())
|
|
||||||
FILE.close()
|
|
||||||
return configurations
|
|
||||||
|
|
||||||
|
|
||||||
def get_bucket(conn, existing_bucket):
|
|
||||||
if existing_bucket:
|
|
||||||
return conn.get_bucket(existing_bucket)
|
|
||||||
else:
|
|
||||||
goop = '%x' % random.getrandbits(64)
|
|
||||||
bucket = conn.create_bucket(goop)
|
|
||||||
bucket.set_acl('public-read')
|
|
||||||
return bucket
|
|
||||||
|
|
||||||
|
|
||||||
def connect_s3(host, access_key, secret_key):
|
def connect_s3(host, access_key, secret_key):
|
||||||
conn = S3Connection(
|
conn = S3Connection(
|
||||||
calling_format = OrdinaryCallingFormat(),
|
calling_format = OrdinaryCallingFormat(),
|
||||||
|
@ -82,7 +62,7 @@ def generate_objects(bucket, quantity, mean, stddev, seed, checksum=False):
|
||||||
key = Key(bucket)
|
key = Key(bucket)
|
||||||
key.key = name_generator.next()
|
key.key = name_generator.next()
|
||||||
key.set_contents_from_file(fp)
|
key.set_contents_from_file(fp)
|
||||||
url = key.generate_url(3600) #valid for 1 hour
|
url = key.generate_url(30758400) #valid for 1 year
|
||||||
if checksum:
|
if checksum:
|
||||||
url += ' %s' % key.md5
|
url += ' %s' % key.md5
|
||||||
urls.append(url)
|
urls.append(url)
|
||||||
|
@ -91,8 +71,9 @@ def generate_objects(bucket, quantity, mean, stddev, seed, checksum=False):
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
'''To run the static content load test:
|
'''To run the static content load test, make sure you've bootstrapped your
|
||||||
./generate_objects.py -a S3_ACCESS_KEY -s S3_SECRET_KEY -O urls.txt --seed 1234 generate_objects.conf && siege -rc ./siege.conf -r 5
|
test environment and set up your config.yml file, then run the following:
|
||||||
|
S3TEST_CONF=config.yml virtualenv/bin/python generate_objects.py -a S3_ACCESS_KEY -s S3_SECRET_KEY -O urls.txt --seed 1234 && siege -rc ./siege.conf -r 5
|
||||||
|
|
||||||
This creates a bucket with your S3 credentials and fills it with
|
This creates a bucket with your S3 credentials and fills it with
|
||||||
garbage objects as described in generate_objects.conf. It writes a
|
garbage objects as described in generate_objects.conf. It writes a
|
||||||
|
@ -102,6 +83,9 @@ def main():
|
||||||
|
|
||||||
Results are printed to the terminal and written in CSV format to
|
Results are printed to the terminal and written in CSV format to
|
||||||
./siege.log
|
./siege.log
|
||||||
|
|
||||||
|
S3 credentials and output file may also be specified in config.yml
|
||||||
|
under s3.main and file_generation.url_file
|
||||||
'''
|
'''
|
||||||
(options, args) = parse_opts();
|
(options, args) = parse_opts();
|
||||||
|
|
||||||
|
@ -109,19 +93,30 @@ def main():
|
||||||
random.seed(options.seed if options.seed else None)
|
random.seed(options.seed if options.seed else None)
|
||||||
if options.outfile:
|
if options.outfile:
|
||||||
OUTFILE = open(options.outfile, 'w')
|
OUTFILE = open(options.outfile, 'w')
|
||||||
|
elif common.config.file_generation.url_file:
|
||||||
|
OUTFILE = open(common.config.file_generation.url_file, 'w')
|
||||||
else:
|
else:
|
||||||
OUTFILE = sys.stdout
|
OUTFILE = sys.stdout
|
||||||
|
|
||||||
conn = connect_s3(options.host, options.access_key, options.secret_key)
|
if options.access_key and options.secret_key:
|
||||||
|
host = options.host if options.host else common.config.s3.defaults.host
|
||||||
|
conn = connect_s3(host, options.access_key, options.secret_key)
|
||||||
|
else:
|
||||||
|
conn = common.s3.main
|
||||||
|
|
||||||
|
if options.bucket:
|
||||||
bucket = get_bucket(conn, options.bucket)
|
bucket = get_bucket(conn, options.bucket)
|
||||||
|
else:
|
||||||
|
bucket = common.get_new_bucket()
|
||||||
|
|
||||||
urls = []
|
urls = []
|
||||||
|
|
||||||
print >> OUTFILE, 'bucket: %s' % bucket.name
|
print >> OUTFILE, 'bucket: %s' % bucket.name
|
||||||
print >> sys.stderr, 'setup complete, generating files'
|
print >> sys.stderr, 'setup complete, generating files'
|
||||||
for profile in parse_config(args):
|
for profile in common.config.file_generation.groups:
|
||||||
seed = random.random()
|
seed = random.random()
|
||||||
urls += generate_objects(bucket, profile[0], profile[1], profile[2], seed, options.checksum)
|
urls += generate_objects(bucket, profile[0], profile[1], profile[2], seed, options.checksum)
|
||||||
print >> sys.stderr, 'finished sending files. Saving urls to S3'
|
print >> sys.stderr, 'finished sending files. generating urls and sending to S3'
|
||||||
|
|
||||||
url_string = '\n'.join(urls)
|
url_string = '\n'.join(urls)
|
||||||
url_key = Key(bucket)
|
url_key = Key(bucket)
|
||||||
|
@ -132,5 +127,10 @@ def main():
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
common.setup()
|
||||||
|
try:
|
||||||
main()
|
main()
|
||||||
|
except Exception as e:
|
||||||
|
traceback.print_exc()
|
||||||
|
common.teardown()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue