我有一个简单的java程序,可以在并行线程中向服务器发送10,000个HTTP请求。
许多请求以200 OK响应代码成功完成,但部分请求失败并显示以下消息:
java.net.SocketException:连接重置为 java.net.SocketInputStream.read(SocketInputStream.java:196)at java.net.SocketInputStream.read(SocketInputStream.java:122)at java.io.BufferedInputStream.fill(BufferedInputStream.java:235)at java.io.BufferedInputStream.read1(BufferedInputStream.java:275)at java.io.BufferedInputStream.read(BufferedInputStream.java:334)at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:689)at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:633)at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:660)at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1324)
我的代码是:
import java.io.*;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.DataOutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.util.*;
import org.json.JSONException;
import org.json.JSONObject;
import org.json.JSONArray;
import java.io.OutputStreamWriter;
import java.io.DataOutputStream;
public class CreateUsers {
public static void main(String[] args){
System.out.println(Thread.currentThread().getName());
for(int i=0; i<10000; i++){
final int cnt = i;
new Thread("" + i){
public void run(){
try {
String url = "http://myurl.com"; //I use my actual server url here
URL object=new URL(url);
HttpURLConnection con = (HttpURLConnection) object.openConnection();
con.setDoOutput(true);
con.setRequestMethod("POST");
con.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
JSONObject parent=new JSONObject();
JSONObject all_users=new JSONObject();
all_users.put("user_name", "abc");
all_users.put("email", "test"+cnt+"@test.com");
JSONArray users = new JSONArray();
users.put(all_users);
parent.put("users", users);
OutputStream os = con.getOutputStream();
os.write(parent.toString().getBytes("UTF-8"));
os.close();
int responseCode = con.getResponseCode();
System.out.println("\nSending 'POST' request to URL : " + url);
System.out.println("Response Code : " + responseCode);
con.disconnect();
}
catch (Exception e) {e.printStackTrace();}
}
}.start();
}
}
}
更新
由于这里的答案指出我的服务器正在中止传入的尝试,我想知道我需要做什么样的服务器调整,以便能够模拟10,000个传入请求。
我的服务器是在ubuntu上运行的amazon ec2实例,apache tomcat 7,30G RAM,4个CPU。
答案 0 :(得分:4)
您基本上是在机器上进行拒绝服务攻击。 Web服务器无法处理那么多的并发连接,必须中止一些传入的尝试。
如果您打算编写这样的工具,它似乎工作得很好。否则,请说明您实际想要完成的任务。
答案 1 :(得分:1)
如果您确实发送了10.000个请求,我怀疑正在处理您请求的服务器放弃了一些请求,因为它太忙或在处理您的请求时遇到其他异常。