您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

php使用swoole的应用场景有哪些?

2024/4/13 21:13:40发布17次查看
php使用swoole的应用场景有:1、实时收集定位数据并实时输出,需要将所有的定位设备实时的接收,将实时的轨迹记录显示在地图上;2、只收集定位设备入库,需要把所有的定位设备上传的数据入库。
php使用swoole的应用场景有:
场景1 - 实时收集定位数据实时输出(例 滴滴司机行驶轨迹)
说明:
需要将所有的定位设备实时的接收,将实时的轨迹记录显示在地图上
注意点:
第一点:
web1服务器 连接的用户1,2,3,web1广播信息时只能广播用户1,2,3,不能广播web2连接的用户4,5,6,假设场景是聊天,用户1发送一消息,只有web1 服务器的用户能看到,web2的用户全部不能收到
第二点:消息的频率控制,例:100个设备,100个用户, 100个设备每秒上传一条数据,需要实时广播给每个用户,就是每秒要100*100 = 1w次,所以可以汇总每秒数据广播给所有用户等等方法
场景2 - 只收集定位设备入库
说明:需要把所有的定位设备上传的数据入库,设备7个,每秒一条数据,个人使用swoole 的task 函数(投递一个异步的任务到 task_worker池中,此函数是非阻塞的, worker进程数同样可以配置) 后调用接口方式入库
服务器内存报警问题
原因: 在于swoole_server->task 函数
官方介绍task底层使用unix socket管道通信,是全内存的,没有io消耗。单进程读写性能可达100万/s,不同的进程使用不同的管道通信,可以最大化利用多核。
但这任务如果是调用程序接口时,由于网络的延迟,增加的任务大于消费的任务时,内存占用会不断的增加,导致服务器的内存被占满。
解决方法:消息针对入任务的频率控制,可以根据自己的业务场景定义这个时间与是否可延迟等情况,汇总1秒内的所有数据再调用程序接口(汇总时个人使用redis),最好能直接入库,不必调用接口
简单代码片段
function __construct($config) { $this->config = $config; $this->serv = new swoole\server($config['server']['host'], $config['server']['port']); // 连接redis $this->redis = new predis\client($config['redis']); $this->storage = new storage($this->config); $this->serv->set([ 'worker_num' => $this->config['server']['workernum'], //工作进程数量 'daemonize' => $this->config['server']['daemonize'], //是否作为守护进程 'task_worker_num' => $this->config['server']['taskworkernum'], ]); $this->serv->on('connect', function ($serv, $fd){ $this->onconnect($fd, $serv); }); $this->serv->on('receive', function ($serv, $fd, $from_id, $data) { $this->onreceive($fd, $serv, $data); }); $this->serv->on('close', function($server, $fd) { $this->onclose($fd, $server); }); $this->serv->on('task', function($server, $task_id, $from_id, $data) { $this->ontask($server, $task_id, $from_id, $data); }); $this->serv->on('finish', function($server, $task_id, $data) { $this->onfinish($server, $task_id, $data); }); $this->serv->start();}public function ontask($serv, $task_id, $from_id, $data){ // insert 方法是通过接口入库 $this->storage->insert($data);}public function onreceive($fd, $serv, $data){ $this->storage->writelog('message:'.$data); $data = $this->formatdata($data, $fd); $serv->task($data);}public function onclose($fd, $serv) { // writelog 方法是写入log $this->storage->writelog('close fd:'.$fd);}public function onfinish($serv, $task_id, $data){ return '';}
相关学习推荐:php编程从入门到精通
以上就是php使用swoole的应用场景有哪些?的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product