-
Notifications
You must be signed in to change notification settings - Fork 10
v3.4 Multiuser Load Case
Andrey Kurilov edited this page Jul 25, 2017
·
5 revisions
The multiuser load case is a specific extension of more general Configuration Parameterization feature. Please read it to understand the configuration patterns used below.
Let's realize the case when someone needs to perform a load using many (hundreds, thousands) destination paths (S3 buckets, Swift containers, filesystem directories, etc) using many different credentials.
Example scenario:
{
"type" : "load",
"config" : {
"item" : {
"data" : {
"size" : "10KB"
},
"output" : {
"file" : "objects.csv",
"path" : "bucket-%d(314159265){00}[0-99]"
}
},
"storage" : {
"auth" : {
"file" : "credentials.csv",
"uid" : "user-%d(314159265){00}[0-99]"
},
"driver" : {
"concurrency" : 10,
"type" : "s3"
}
},
"test" : {
"step" : {
"limit" : {
"count" : 10000
}
}
}
}
}
Note that:
- Missing buckets will be created on demand.
- The seed value "314159265" should be used to init the internal PRNG to align the bucket names with user ids (The same "XY" value for each pair of "bucket-XY" and "user-XY" supplied).
- The current credentials count limit is 1 million.
In this case, the file "credentials.csv" should be prepared manually. Example contents:
user-00,secret-00
user-01,secret-01
user-02,secret-02
...
user-99,secret-99
(in the real world it is expected that the storage users with the listed names and secret keys are already existing)
To make such example file you may use the following 2 commands:
for i in $(seq 0 9); do echo "user-0$i,secret-0$i" >> credentials.csv; done;
for i in $(seq 10 99); do echo "user-$i,secret-$i" >> credentials.csv; done
- Overview
- Deployment
- User Guide
- Troubleshooting
- Reference