123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- using System;
- using System.Threading;
- using CLClient.Statistics;
- using Sers.Core.CL.CommunicationManage;
- using Vit.Core.Module.Log;
- using Vit.Core.Util.Pipelines;
- using Vit.Core.Util.Threading;
- namespace CLClient
- {
- class ProgramQps
- {
- static StatisticsQpsInfo qpsInfo = new StatisticsQpsInfo();
- static void Main(string[] args)
- {
- Logger.OnLog = (level, msg) => { Console.Write("[" + level + "]" + msg); };
- qpsInfo.Start("Msg");
- for (int i = Vit.Core.Util.ConfigurationManager.ConfigurationManager.Instance.GetByPath<int>("PressureTest.clientCount"); i >0; i--)
- {
- StartThreadSendMessage();
- }
- while (true)
- {
- Thread.Sleep(5000);
- }
- }
-
- static void StartThreadSendMessage()
- {
- CommunicationManageClient cm = new CommunicationManageClient();
-
- cm.Conn_OnDisconnected = (conn) =>
- {
- Logger.Info("Conn_OnDisconnected");
- Sers.Core.Module.App.SersApplication.OnStop();
- };
- cm.conn_OnGetRequest = (conn,sender,request,callback)=>
- {
- qpsInfo.IncrementRequest();
- callback(sender,new Vit.Core.Util.Pipelines.ByteData (request));
- };
- cm.conn_OnGetMessage = (conn,msg) =>
- {
- qpsInfo.IncrementRequest();
- cm.SendMessageAsync(new Vit.Core.Util.Pipelines.ByteData (msg));
- };
- if (!cm.Start())
- {
- return;
- }
- byte[] buff = new byte[Vit.Core.Util.ConfigurationManager.ConfigurationManager.Instance.GetByPath<int>("PressureTest.msgLen")];
- for (int i = Vit.Core.Util.ConfigurationManager.ConfigurationManager.Instance.GetByPath<int>("PressureTest.messageThreadCount"); i > 0; i--)
- {
- cm.SendMessageAsync(new ByteData(buff));
- }
- int theadCount = Vit.Core.Util.ConfigurationManager.ConfigurationManager.Instance.GetByPath<int>("PressureTest.requestThreadCount");
- if (theadCount >= 0)
- {
- ///*/
- var conn = cm.organizeList[0].conn;
- Action<object, ByteData> callback = null;
- callback = (sender, data) =>
- {
- qpsInfo.IncrementRequest();
- conn.SendRequestAsync(null, data, callback);
- };
- for (int t = theadCount; t > 0; t--)
- {
- callback(null, new ByteData(buff));
- }
- /*/
- LongTaskHelp task = new LongTaskHelp();
- task.threadName = "PressureTest.SendRequest";
- task.threadCount = theadCount;
- task.action = () =>
- {
- var conn = cm.organizeList[0].conn;
- for (; ; )
- {
- if (conn.SendRequest(new ByteData(buff), out _))
- qpsInfo.IncrementRequest();
- }
- };
- task.Start();
- //*/
- }
-
- }
- }
- }
|