我正在尝试开发一个小型应用程序来测试我的服务每秒可以支持多少个请求,但我认为我做错了。该服务处于早期开发阶段,但我希望方便地进行此测试,以便不时检查我没有做会降低性能的事情。问题是我无法让 Web 服务器或数据库服务器使用 100% 的 CPU。
我正在使用三台不同的计算机,一台是 Web 服务器(WinSrv Standard 2008 x64 IIS7),另一台是数据库(Win 2K,SQL Server 2005),最后一台是我的计算机(Win7 x64 Ultimate),我将在其中运行测试。计算机通过 100 以太网交换机连接。请求 POST 为 9 个字节,响应为 842 个字节。
测试启动了几个线程,每个线程都有一个while
循环,在每个循环中它创建一个WebRequest
对象,执行一个调用,增加一个公共计数器并等待 1 到 5 毫秒,然后再做一次:
static int counter = 0;
static void Main(string[] args)
{
ServicePointManager.DefaultConnectionLimit = 250;
Console.WriteLine("Ready. Press any key...");
Console.ReadKey();
Console.WriteLine("Running...");
string localhost = "localhost";
string linuxmono = "192.168.1.74";
string server = "192.168.1.5:8080";
DateTime start = DateTime.Now;
Random r = new Random(DateTime.Now.Millisecond);
for (int i = 0; i < 50; i++)
{
new Thread(new ParameterizedThreadStart(Test)).Start(server);
Thread.Sleep(r.Next(1, 3));
}
Thread.Sleep(2000);
while (true)
{
Console.WriteLine("Request per second :"
+ counter / DateTime.Now.Subtract(start).TotalSeconds);
Thread.Sleep(3000);
}
}
public static void Test(object ip)
{
Guid guid = Guid.NewGuid();
Random r = new Random(DateTime.Now.Millisecond);
while (true)
{
String test = "<lalala/>";
WebRequest req = WebRequest.Create("http://"
+ (string) ip + "/WebApp/" + guid.ToString()
+ "/Data/Tables=whatever");
req.Method = "POST";
req.ContentType = "application/xml";
req.Credentials = new NetworkCredential("aaa", "aaa","domain");
byte[] array = Encoding.UTF8.GetBytes(test);
req.ContentLength = array.Length;
using (Stream reqStream = req.GetRequestStream())
{
reqStream.Write(array, 0, array.Length);
reqStream.Close();
}
using (Stream responseStream = req.GetResponse().GetResponseStream())
{
String response = new StreamReader(responseStream).ReadToEnd();
if (response.Length != 842) Console.Write(" EEEE ");
}
Interlocked.Increment(ref counter);
Thread.Sleep(r.Next(1,5));
}
}
如果我运行测试,两台计算机都不会过度使用 CPU。假设我每秒收到 X 个请求,如果我同时运行控制台应用程序两次,我每次收到 X/2 个请求......但 Web 服务器仍然占用 30% 的 CPU,数据库服务器在 25%...
我试图删除Thread.Sleep
循环中的,但这并没有太大的区别。
我想将机器调到最大,以检查它们每秒可以提供多少请求。我猜我可以这样做......但显然我在这里遗漏了一些东西......有什么问题?
亲切的问候。