-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcreate_objects.py
executable file
·67 lines (55 loc) · 1.91 KB
/
create_objects.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#!/usr/bin/env python
import boto.exception
import boto.s3.connection
import boto.s3.acl
import argparse
import os
import threading
from boto.connection import AWSAuthConnection
def create_objs(bucket, start, end):
print 'creating objs start '+ `start` + ' end ' + `end`
for i in range(start, end):
obj = boto.s3.key.Key(bucket)
obj.key = 'obj' + `i`
print 'creating '+ obj.key
obj.set_contents_from_string('This is a test of S3')
def list_bucket(bucket):
print 'list objects'
i = 0
for k in bucket.list():
print 'obj ' + `i`
print k
i = i + 1
parser = argparse.ArgumentParser(description='create objects')
parser.add_argument('--num', type=int, action='store', default=100 )
parser.add_argument('--bucket', type=str, action='store', default='bucket1' )
parser.add_argument('--host', type=str, action='store', default='127.0.0.1' )
parser.add_argument('--port', type=int, action='store', default=8000)
parser.add_argument('--slice', type=int, action='store', default=1000)
parser.add_argument('--num_threads', type=int, action='store', default=1)
args = parser.parse_args()
s3_access_key=os.environ['S3_ACCESS_KEY_ID']
s3_secret_key=os.environ['S3_SECRET_ACCESS_KEY']
connection = boto.s3.connection.S3Connection(
aws_access_key_id=s3_access_key,
aws_secret_access_key=s3_secret_key,
is_secure=False,
port=args.port,
host=args.host,
calling_format=boto.s3.connection.OrdinaryCallingFormat(),
)
print 'create a bucket'
bucket = connection.create_bucket(args.bucket)
start = 0
while start < args.num:
threads = []
num_threads = 0
while num_threads < args.num_threads and start < args.num:
end = min(args.num, start + args.slice)
t = threading.Thread(target=create_objs, args=(bucket, start, end,))
threads.append(t)
t. start()
start += args.slice
num_threads += 1
for t in threads:
t.join()