LaravelS通过Swoole加速Laravel/Lumen详解
LaravelS - 站在巨人的肩膀上本文主要介绍了LaravelS通过Swoole加速Laravel/Lumen的相关内容,关于:rocket: 通过Swoole来加速 Laravel/Lumen,其中的S代表Swoole,速度,高性能。 特性
如果对你有帮助,Star Me 要求
安装1.通过 安装( ) 2.添加service provider Laravel : 修改文件 config/app.php [
//...
Hhxsv5LaravelSIlluminateLaravelSServiceProvider::class,],
Lumen : 修改文件 bootstrap/app.php register(Hhxsv5LaravelSIlluminateLaravelSServiceProvider::class);
3.发布配置文件 特别情况 : 你不需要手动加载配置 laravels.php ,LaravelS底层已自动加载。 configure('laravels');
4.修改配置 config/laravels.php :监听的IP、端口等,请参考 配置项 。 运行
与Nginx配合使用 Nginx处理静态资源,LaravelS处理动态资源。
location / { location @laravels { proxy_connect_timeout 60s;proxy_send_timeout 60s;proxy_read_timeout 120s;proxy_set_header Connection "keep-alive"; 监听事件通常,你可以在这些事件中重置或销毁一些全局或静态的变量,也可以修改当前的请求和响应。 laravels.received_request 将 swoole_http_request 转成 IlluminateHttpRequest 后,在Laravel内核处理请求前。 listen('laravels.received_request',function (IlluminateHttpRequest $req) {
$req->query->set('get_key','hhxsv5');// 修改querystring
$req->request->set('post_key','hhxsv5'); // 修改post body
});
laravels.generated_response 在Laravel内核处理完请求后,将 IlluminateHttpResponse 转成 swoole_http_response 之前(下一步将响应给客户端)。 listen('laravels.generated_response',function (IlluminateHttpRequest $req,SymfonyComponentHttpFoundationResponse $rsp) {
$rsp->headers->set('header-key','hhxsv5');// 修改header
});
在你的项目中使用 swoole_http_server 实例 stats());
注意事项 推荐通过 IlluminateHttpRequest 对象来获取请求信息,兼容$_SERVER、$_GET、$_POST、$_FILES、$_COOKIE、$_REQUEST, 不能使用 $_SESSION、$_ENV。 input('name');
$all = $request->all();
$sessionId = $request->cookie('sessionId');
$photo = $request->file('photo');
$rawContent = $request->getContent();
//...
}
推荐通过返回 IlluminateHttpResponse 对象来响应请求,兼容echo、vardump()、print_r(), 不能使用 函数像exit()、 json(['time' => time()])->header('header1','value1')->withCookie('c1','v1');
}
你声明的全局、静态变量必须手动清理或重置。 无限追加元素到静态或全局变量中,将导致内存爆满。 // 某控制器
public function test(Request $req) { // 内存爆满 Test::$array[] = $req->input('param1'); Test::$string .= $req->input('param2'); } 待办事项
总结以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |