我正在编写一个Jmeter测试计划,以将文件分块上传到服务器。我对Java不太了解。
我在 HTTP Request Sampler 上将 while控制器与 Bean Shell预处理器一起使用。我编写了一个简短的脚本来从文件中获取字节,现在我面临的问题是:HTTP请求采样器在“文件上传”部分中获取文件路径。有什么方法可以在Bean Shell预处理器的内存中创建文件,然后在“文件路径”字段中使用该内存文件变量。
我认为理论上是可能的。因为无论何时上传文件,我们都会先将其存储到内存中,然后再发送到服务器。因此,我们能否仅在内存中从字节(1 MB的块)创建文件,然后将其作为文件上传发送。这是我在Bean Shell预处理器中编写的代码
Integer maxChunkSize = new Integer(vars.get("FILE_MAX_SIZE"));
String uploadFilePath = vars.get("UPLOAD_FILE");
uploadFileSize = new File(uploadFilePath).length();
InputStream uploadFile = new BufferedInputStream(new FileInputStream(uploadFilePath));
int offset = whileCounter * maxChunkSize;
ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] bytes;
int size;
/* creating bytes array to hold file data*/
if (offset < uploadFileSize) {
if (((int) offset + (int) maxChunkSize) < uploadFileSize) {
bytes = new byte[ (int) maxChunkSize];
size = maxChunkSize;
} else {
size = (int) (uploadFileSize - offset);
bytes = new byte[ (int) size];
vars.put("WHILE_LOOP", "0");
}
}
/* printing results for debugging */
/*
log.info(" ============================================================== ");
log.info("While counter " + whileCounter.toString() );
log.info("While loop " + vars.get("WHILE_LOOP").toString() );
log.info("The file to upload is : " + uploadFilePath);
log.info("Maximum Chunk size is : " + maxChunkSize.toString());
log.info("Current Offset is : " + offset.toString());
log.info("The file size is " + uploadFileSize.toString());
log.info(" ============================================================== ");
*/
/* here it is giving method invocation on loop counter 2, so skip method is used */
uploadFile.skip(offset);
int bytesRead = uploadFile.read(bytes, 0, size);
/* write to byte output stream to read as a file */
bos.write(bytes, 0, bytesRead);
/* params for next iteration */
uploadFile.close();
whileCounter++;
vars.put("WHILE_COUNTER", whileCounter.toString() );
预期:通过JMeter批量上传文件的替代方法或创建一个内存变量,该变量将用作JMeter HTTP Request Sampler中文件上传路径的文件-> 文件上传部分。
答案 0 :(得分:0)
我认为您无法使用HTTP Request采样器来实现此目的,我会考虑以下选项:
Implement chunked file upload using Java code,而无需依赖JMeter的HTTP Request采样器,例如
import org.apache.http.client.methods.HttpPost
import org.apache.http.entity.InputStreamEntity
import org.apache.http.impl.client.CloseableHttpClient
import org.apache.http.impl.client.HttpClients
CloseableHttpClient client = HttpClients.createDefault();
HttpPost post = new HttpPost("http://example.com");
File file = new File("/path/to/your/file");
InputStreamEntity reqEntity = new InputStreamEntity(new FileInputStream(file), -1, "Your file mime type");
//Alternatively:
//FileEntity reqEntity = new FileEntity(file, "Your file mime type");
reqEntity.setChunked(true);
client.execute(post)
转到HTTP Raw Request采样器,该采样器简单地通过线路发送分块数据(可以通过kg.apc.jmeter.samplers.FileReadChunkSize
属性控制分块的大小),因此您可以使用像Wireshark这样的嗅探器工具,然后以所需的块大小重播它。如果需要,请查看The JMeter HTTP Raw Request Sampler - When and How to Use It文章以获取更多信息。
还请注意since JMeter 3.1 it's recommended to use JSR223 Test Elements and Groovy language for scripting,因此请考虑在下一个可用机会时迁移到Groovy。