int httpTestMain(int npar,char **par) { int i,sock=1,pack=1,logLevel=1; int MaxPacket = 1000000; char *url,*Proxy=""; net_init(); signal(SIGINT,sig_done); if (npar<2) { httpTestHelp(); return 1; // Error } char *cmd=par[1]; if (strncmp(cmd,"-p",2)==0) return MicroHttpMain(npar,par); if (strncmp(cmd,"http://",7)==0) cmd+=7; // RemoveHTTP url=cmd; static Counter read={100000}; // ReadLimit for(i=2;i<npar;i++) { // Decode Optional char *cmd=par[i]; int ok=1; if (*cmd=='-') { cmd++; ok=1; if (*cmd=='s') sscanf(cmd+1,"%d",&sock); //else if (*cmd=='S') sscanf(cmd+1,"%d",&sleepTime); else if (*cmd=='p') sscanf(cmd+1,"%d",&pack); else if (*cmd=='d') sscanf(cmd+1,"%d",&logLevel); else if (*cmd=='M') sscanf(cmd+1,"%d",&MaxPacket); else if (*cmd=='P') Proxy=cmd+1; else if (*cmd=='R') sscanf(cmd+1,"%d",&ReplayCode); else if (*cmd=='r') sscanf(cmd+1,"%d",&read.Limit); else ok=0; } if (!ok) { printf("httpTest - unknownParameter: '%s'\n",cmd); httpTestHelp(); return 2; } } //thread_create(httpClientTest1); httpClient *Cli[sock]; logger *log; log = logOpen("httpTest.log"); Logf("httpStressTest: {logLevel:%d,Sockets:%d,Commands:%d,MaxPacket:%d,URL:'%s',Proxy='%s'\n", logLevel,sock,pack,MaxPacket,url,Proxy); for(i=0;i<sock;i++) { httpClient *c; Cli[i]= c = httpClientNew(); c->log = log; c->logLevel = logLevel; snprintf(c->name,sizeof(c->name),"[%d]%s",i,url); if (!httpClientInit(c,url,Proxy)) return 0; c->onDisconnect = onTestDisconnect; c->sock.readPacket = &read; //c->sock->readPacket.Limit = readPackLimit; //printf("Begin?\n"); int j; for(j=0;j<pack;j++) SendTestPack(c); // SendTestPacks //printf("Done?\n"); } TimeUpdate(); time_t Started=TimeNow; printf("StressStarted: %s, mem=%d\n",szTimeNow,os_mem_used()); while(!aborted) { int c=0; TimeUpdate(); for(i=0;i<sock;i++) if (httpClientRun(Cli[i])) c++; if (read.Total>=MaxPacket) { Logf("MaxPacket %d received\n", MaxPacket); break; } //printf("Run=%d\n",c); RunSleep(c); if (NeedReport()) Reportf("Time:'%s',Packet_Per_Second:%5d,Total:%5d,os_mem:%d",szTimeNow, (read.pValue+read.ppValue)/2,read.Total,os_mem_used()); //if (!c) msleep(1); } TimeUpdate(); int Dur=TimeNow-Started,PPS=0; if (Dur) PPS=read.Total/Dur; printf("StressStopped:'%s',Dur:%d,PPS:%d,Total:%5d,os_mem:%d",szTimeNow,Dur,PPS,read.Total,os_mem_used()); return 0; //return httpClientTest1(logLevel,sock,pack,url); // Слушай - а у меня в микрохттп нету ли такого - что я останавливаюсь??? }
int MicroHttpMain(int npar,char **par) { int i,Limit=1000000; if (npar==1) { printf("microHttp.exe -p[port] -r[rootDir] -d[debugLevel] -m[ext=mime[&..]]) -L[limitPPS:1000000] -S[cert.pem]\n"); return 0; } for(i=1;i<npar;i++) { char *cmd = par[i]; if (*cmd=='-') cmd++; switch(*cmd) { case 'p': sscanf(cmd+1,"%d",&port); break; //case 'S': sscanf(cmd+1,"%d",&sleepTime); break; case 'd': sscanf(cmd+1,"%d",&logLevel); break; case 'k': sscanf(cmd+1,"%d",&keepAlive); break; case 'T': sscanf(cmd+1,"%d",&runTill); break; case 'L': sscanf(cmd+1,"%d",&Limit); break; case 'r': rootDir=cmd+1; break; case 'm': mimes = cmd+1; break; case 'S': pem = cmd+1; break; } } net_init(); TimeUpdate(); httpSrv *srv = httpSrvCreate(0); // New Instance, no ini srv->log = srv->srv.log = logOpen("microHttp.log"); // Create a logger srv->logLevel = srv->srv.logLevel = logLevel; srv->keepAlive=keepAlive; srv->readLimit.Limit = Limit; #ifdef VOS_SSL if (pem) { srv->srv.pem_file=pem; // if have SSL printf("SSL will use pem_file: %s\n",pem); } else printf("==NO SSL==, use plain tcp_sockets\n"); #endif ws = wsSrvCreate(); ws->onMessage = onWebMessage; IFLOG(srv,0,"...starting microHttp {port:%d,logLevel:%d,rootDir:'%s',keepAlive:%d,Limit:%d},\n mimes:'%s'\n", port,logLevel,rootDir,keepAlive,Limit, mimes); //printf("...Creating a http server\n"); srv->defmime= vssCreate("text/plain;charset=utf-8",-1); httpSrvAddMimes(srv,mimes); //httpMime *m = httpSrvGetMime(srv,vssCreate("1.HHtm",-1));printf("Mime here %*.*s\n",VSS(m->mime)); //httpSrvAddFS(srv,"/c/","c:/",0); // Adding some FS mappings httpSrvAddFS(srv,"/",rootDir,0); // Adding some FS mappings httpSrvAddMap(srv, strNew("/.stat",-1), onHttpStat, 0); httpSrvAddMap(srv, strNew("/.chat",-1), onWebSock, 0); if (httpSrvListen(srv,port)<=0) { // Starts listen port Logf("-FAIL start listener on port %d\n",port); return 1; } Logf(".. listener is ready, Ctrl+C to abort\n"); if (runTill) srv->runTill = TimeNow + runTill; //httpSrvProcess(srv); // Run All messages till CtrlC... while(!aborted) { TimeUpdate(); // TimeNow & szTimeNow int cnt = SocketPoolRun(&srv->srv); cnt+=wsSrvStep(ws); //printf("SockPoolRun=%d time:%s\n",cnt,szTimeNow); msleep(1000); RunSleep(cnt); // Empty socket circle -))) if (srv->runTill && TimeNow>=srv->runTill) break; // Done??? } TimeUpdate(); IFLOG(srv,0,"...stop microHttp, done:{connects:%d,requests:%d,runtime:%d}\n", srv->srv.connects,srv->srv.requests,TimeNow - srv->created); return 0; }