在整合swoolehttpserver和phalcon,server.php如下:
registerDirs(array('../apps/controllers/','../apps/models/'));$loader->register();}/***Thismethodsregisterstheservicestobeusedbytheapplication*/protectedfunctionregisterServices(){$di=newDI();//Registeringarouter$di->set('router',function(){returnnewRouter();});//Registeringadispatcher$di->set('dispatcher',function(){returnnewDispatcher();});//RegisteringaHttp\Response$di->set('response',function(){returnnewResponse();});//RegisteringaHttp\Request$di->set('request',function(){returnnewRequest();});//Registeringtheviewcomponent$di->set('view',function(){$view=newView();$view->setViewsDir('../apps/views/');return$view;});$di->set('db',function(){returnnewDatabase(array("host"=>"localhost","username"=>"root","password"=>"","dbname"=>"invo"));});//RegisteringtheModels-Metadata$di->set('modelsMetadata',function(){returnnewMemoryMetaData();});//RegisteringtheModelsManager$di->set('modelsManager',function(){returnnewModelsManager();});$this->setDI($di);}publicfunctionmain(){$this->registerServices();$this->registerAutoloaders();}}$application=null;$http=newswoole_http_server("0.0.0.0",9501);$http->on('request',function($request,$response){try{$_GET=$_POST=$_COOKIE=$_REQUEST=[];if(!empty($request->get)){$_GET=$request->get;$_REQUEST+=$_GET;}if(!empty($request->post)){$_POST=$request->post;$_REQUEST+=$_POST;}if(!empty($request->cookie)){$_COOKIE=$request->cookie;}global$application;$html=$application->handle($request->server['request_uri'])->getContent();$response->end($html);}catch(\Exception$e){print_r($e);echo$e->getMessage();}});$http->on('WorkerStart',function($server,$workerId){global$application;$application=newApplication();$application->main();});#启动服务器$http->start();
浏览器访问没什么问题
做ab测试就报错了
ab-n10000-c1000-rkhttp://phalcon.com/
错误信息:
[root@localhostpublic]#[2016-08-2517:12:45*12502.0]ERRORzm_deactivate_swoole(ERROR103):Fatalerror:Allowedmemorysizeof268435456bytesexhausted(triedtoallocate16384bytes)in/srv/www/single/public/server.phponline126.[2016-08-2517:12:45$12497.0]WARNINGswManager_check_exit_status:worker#0abnormalexit,status=255,signal=0
请教这是什么原因导致的,是onRequest那里写的不对吗?
这个问题,目前我还没找到答案,说下目前的情况
这个是有人写的一个demo:
这个我测了,在ab-n10000-c1000-krhttp://phalcon.com/
这样的测试下,可以做大概7-8轮测试,然后也报
PHPFatalerror:Allowedmemorysizeof268435456bytesexhausted(triedtoallocate16384bytes)in/srv/www/single/public/server.phponline56
特别是配置这里:
$http->set(array('worker_num'=>4,'daemonize'=>true,'max_request'=>100000,'dispatch_mode'=>1));
如果注释掉,也就只能跑一轮,第二次就也报内存不够的问题了
继续探究吧,我也再问问
2016-09-3018:25:18更新
现在找到了问题所在,是控制器里面返回内容所用的方式引起的:
publicfunctionindexAction(){return"helloworld";//这种会导致报Allowedmemoryexhausted}publicfunctionindexAction(){echo"helloworld";//这种不会}
这两种都能正常打印helloworld。
看起来应该是return回去的内容,导致$html没有释放掉?暂时这么猜的,我想看内存里面哪个变量没有释放,但没找到看php的内存变量的方法,有知道的贴个答案。
看起来$application是一个单例,那么内部状态应该会有冲突吧
感觉像是global$application;的缘故,可以建议对于公用的东西走单例模式
$http->on('WorkerStart',function($server,$workerId){global$application;$application=newApplication();$application->main();});
修改成为
$http->on('WorkerStart',function($server,$workerId){$server->application=newApplication();$server->application->main();});
之后你都可以使用$server->application
来访问Application对象了。
如果已上方法你不想这样做,请修改onrequest方法:
$http->on('request',function($request,$response){try{//你的代码global$application;$html=$application->handle($request->server['request_uri'])->getContent();$response->end($html);}catch(\Exception$e){print_r($e);echo$e->getMessage();}finally{unset($application);}});
估计是因为php.ini的memory_limit=256M
限制导致Swoole遇到内存不足:
Fatalerror:Allowedmemorysizeof268435456bytesexhausted
建议分配512MB或者更大.并发越大,Swoole每个工作进程占用的内存也越多.
使用swoole,就会出现内存泄漏的问题,建议拉个进程实时监控内存使用情况,内存达到一定量就重启进程
建议拉个进程实时监控内存使用情况