php Swoole的基本使用
项目中使用的PHP,但由于长耗时的任务,前端提交以后,需要服务端异步响应。
服务器异步有多种方案,包括MQ,fsocket,Swoole等。
Swoole 使用纯 C 语言编写,提供了 PHP 语言的异步多线程服务器,异步 TCP/UDP 网络客户端,异步 MySQL,异步 Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole内置了Http/WebSocket服务器端/客户端、Http2.0服务器端。
最重要的是,完美支持PHP语言。于是使用Swoole搭建了一个异步服务器,提供异步响应,推送,定时任务等一系列工作。
安装
Swoole是C语言编写,采用编译安装的方式。
安装依赖项有:
php-5.3.10 或更高版本
gcc-4.4 或更高版本
make
autoconf
pcre (centos系统可以执行命令:yum install pcre-devel)
安装方式:
phpize #如果命令不存在 请在前面加上php的实际路径
./configure
make
sudo make install
编译完成以后,需要在php.ini中添加扩展
extension=swoole.so
使用
服务端
class Server{
private $serv;
public function __construct() {
$this->serv = new swoole_server("0.0.0.0",9501);
$this->serv->set(array(
//'worker_num' => 1,//一般设置为服务器CPU数的1-4倍
'daemonize' => 1,//以守护进程执行
'max_request' => 10000,'task_worker_num' => 1,//task进程的数量
"task_ipc_mode " => 3,//使用消息队列通信,并设置为争抢模式
'open_length_check' => true,'dispatch_mode' => 1,'package_length_type' => 'N',//这个很关键,定位包头的
'package_length_offset' => 0,//第N个字节是包长度的值
'package_body_offset' => 4,//第几个字节开始计算长度
'package_max_length' => 2000000,//协议最大长度
"log_file" => "/tmp/swoole_test.log" //日志
));
$this->serv->on('Receive',array($this,'onReceive'));
$this->serv->on('Task','onTask'));
$this->serv->on('Finish','onFinish'));
$this->serv->start();
}
public function onReceive( swoole_server $serv,$fd,$from_id,$data ) {
//放入任务队列,开始执行
$task_id = $serv->task( $data );
}
public function onTask($serv,$task_id,$data) {
//做一些事情
}
客户端
class Client{
private $client,$ip,$port,$params;
public function __construct($ip,$params)
{
$this->ip = $ip;
$this->port = $port;
$this->params = $params;
$this->client = new swoole_client(SWOOLE_SOCK_TCP,SWOOLE_SOCK_ASYNC);
$this->client->set(array(
'open_length_check' => true,'package_length_offset' => 0,//第几个字节开始计算长度
'package_max_length' => 2000000,//协议最大长度
));
//设置事件回调函数
$this->client->on('Connect','onConnect'));
$this->client->on('Receive','onReceive'));
$this->client->on('Close','onClose'));
$this->client->on('Error','onError'));
//发起网络连接
$this->client->connect($ip,3);
}
public function onReceive( $cli,$data ) {
echo "Received: " . $data . "n";
}
public function onConnect($cli) {
$data = pack('N',strlen($data)) . $data;
$cli->send($data);
$cli->close();
}
public function onClose( $cli)
{
echo "Connection closen";
}
public function onError()
{
echo "Connect failedn";
}
}
注意问题
'open_length_check' => true,//第N个字节是包长度的值
'package_body_offset' => 4,//第几个字节开始计算长度
'package_max_length' => 2000000,//协长度
这几个是定义帧定界的,因为Swoole的客户端和服务器端通信是TCP连接的,因此得给帧定界符,有多种帧定界方式,具体参考Swoole官方文档。这里其中是用头额外加长度的方式
更多学习内容可以访问【对标大厂】精品PHP架构师教程目录大全,只要你能看完保证薪资上升一个台阶(持续更新)
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以点击链接领取进阶PHP月薪30k>>>架构师成长路线【视频、面试文档免费获取】 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|