时间:2021-05-26
本文实例讲述了php基于 swoole 实现的异步处理任务功能。分享给大家供大家参考,具体如下:
安装swoole:
下载官方swoole压缩包,解压进入目录
$ cd swoole # 进入 swoole 目录$ phpize$ ./configure --with-php-config=/usr/local/php/bin/php-config #注意查看服务器上是否有这个路径$ make && make install修改php.in文件
vi /usr/local/php/lib/php.ini增加如下内容
extension = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20160303/swoole.so" //版本不同路径可能不同保存后重启php-fpm
$ /etc/init.d/php-fpm restartphp -m 命令查看是否添加成功 成功则会看到有swoole模块
$ php -m服务端作为守护进程监控任务,新建server.php:
<?php$serv = new Swoole\Server("127.0.0.1", 9502);$serv->set(array('task_worker_num' => 4));$serv->on('Receive', function($serv, $fd, $from_id, $data) { $task_id = $serv->task("Async"); echo "Dispath AsyncTask: id=$task_id\n";});$serv->on('Task', function ($serv, $task_id, $from_id, $data) { echo "New AsyncTask[id=$task_id]".PHP_EOL; $serv->finish("$data -> OK");});$serv->on('Finish', function ($serv, $task_id, $data) { echo "AsyncTask[$task_id] Finish: $data".PHP_EOL;}); $serv->start();用命令行模式打开
php server.php新建一个client.php
<?php$client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC);$client->on("connect", function(swoole_client $cli) { $cli->send("GET / HTTP/1.1\r\n\r\n");});$client->on("receive", function(swoole_client $cli, $data){ echo "Receive: $data"; $cli->send(str_repeat('A', 100)."\n"); sleep(1);});$client->on("error", function(swoole_client $cli){ echo "error\n";});$client->on("close", function(swoole_client $cli){ echo "Connection close\n";});$client->connect('127.0.0.1', 9502);打开一个新的窗口命令行执行
php client.php执行完后会发现在server.php的窗口就会有信息输出
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP进程与线程操作技巧总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了php异步多线程swoole用法。分享给大家供大家参考。具体分析如下:swoole重新定义PHP语言的高性能网络通信框架,提供了PHP语言的异步多
100多行PHP代码实现socks5代理服务器,这次是使用swoole纯异步来写,使用状态机来处理数据。目前用它访问开源中国木有压力,但访问网易新闻就压力山大。
在实际开发中,有时候为了及时处理请求和进行响应,我们可能会多任务同时执行,或者先处理主任务,也就是异步调用,异步调用的实现有很多,例如多线程、定时任务、消息队列
celery简介celery是一个基于分布式消息传输的异步任务队列,它专注于实时处理,同时也支持任务调度。它的执行单元为任务(task),利用多线程,如Even
目前常用的异步文件上传功能有几种,比较多见的如使用iframe框架形式,ajax功能效果,以及flash+php功能,下面介绍ajax与iframe实现异步文件