我正在尝试开发一个小应用程序,测试每秒我的服务可以支持多少个请求,但我认为我做错了什么。该服务正处于早期开发阶段,但我希望能够进行此测试,以便不时检查我是否做了可能会降低性能的事情。问题是我无法让Web服务器或数据库服务器转到100%的CPU。我使用三台不同的计算机,一台是Web服务器(WinSrv Standard 2008 x64 IIS7),另一台是数据库(Win 2K,SQL Server 2005),最后一台是我的电脑(Win7 x64 Ultimate),我将在哪里运行测试。计算机通过100以太网交换机连接。请求POST是9个字节,响应将是842个字节。Web服务的小性能测试
测试启动多个线程,每个线程具有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服务器占CPU的30%,数据库服务器上的25%...
我试图删除循环中的Thread.Sleep
,但它并没有太大的区别。
我想把机器放到最大限度,以检查它们可以提供的每秒请求数。我猜想我可以这样做...但显然我在这里失去了一些东西......这是什么问题?
亲切的问候。
我想这实际上是一个配置问题与您的服务器,您可能只能设置为使用一个核心。您可能会在serverfault上获得更多帮助。 – tloach 2010-04-09 19:12:52