Swoole是:PHP语言的高性能网络通信框架,提供了PHP语言的异步多线程服务器,处理异步任务,异步TCP/UDP网络客户端,异步MySQL,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole虽然是标准的PHP扩展,实际上与普通的扩展不同。普通的扩展只是提供一个库函数。而swoole扩展在运行后会接管PHP的控制权,进入事件循环。当IO事件发生后,swoole会自动回调指定的PHP函数。
一:两种安装方式:1》编译安装:1>wget http://pecl.php.net/get/swoole-1.9.6.tgz 或者 wget http://www.taikongliu.com/swoole/swoole-1.7.6-stable.tar.gz //下载swoole 2>tar -zxvf swoole-1.7.6-stable.tar.gz //解压swoole3>cd swoole-src-swoole-1.7.6-stable/ //进入swoole4>/phpstudy/server/php/bin/phpize //生成configure5>./configure --with-php-config=/phpstudy/server/php/bin/php-config //编译6>make && make install //安装7>cd /phpstudy/server/php/lib/php/extensions/no-debug-non-zts-20121212 //查看是否安转上了swoole.so (注意:此文件下边都是你安装的拓展)8>vim /phpstudy/server/php/etc/php.ini //在php.ini添加extension=swoole.so加入到文件最后一行9>/phpstudy/server/nginx/sbin/nginx -s reload //重启nginx 10>查看phpinfo,这时候swoole拓展已经装上了2》PECL安装:1>pecl install swoole //如果以上步骤一切正常的话,即表示swoole已经成功的安装了。2>extension=swoole.so //成功之后,我们打开php.ini(不知道配置文件在哪的回去再把CLI看一遍),把swoole.so加入到文件最后3>$ php -m | grep swoole //查看swoole是否被正确的安装如如果想要升级swoole:pecl upgrade swoole二:服务器端运行程序1>创建server.php<?php$serv = new swoole_server('127.0.0.1', 9501); //server的创建,只需要绑定要监听的ip和端口,如果ip指定为127.0.0.1,则表示客户端只能位于本机才能连接,其他计算机无法连接。//端口这里指定为9501,可以通过netstat查看下该端口是否被占用。如果该端口被占用,可更改为其他端口,如9502,9503等。$serv->set([ //我开2个worker进程处理我们的业务 'worker_num' => 2,]);// 有新的客户端连接时,worker进程内会触发该回调$serv->on('Connect', function ($serv, $fd) { echo "new client connected." . PHP_EOL;});//参数$serv是我们一开始创建的swoole_server对象,//参数$fd是唯一标识,用于区分不同的客户端,同时该参数是1-1600万之间可以复用的整数。// server接收到客户端的数据后,worker进程内触发该回调$serv->on('Receive', function ($serv, $fd, $fromId, $data) { // 收到数据后发送给客户端 $serv->send($fd, 'Server '. $data);});// 客户端断开连接或者server主动关闭连接时 worker进程内调用$serv->on('Close', function ($serv, $fd) { echo "Client close." . PHP_EOL;});// 启动server$serv->start();?>2>由于swoole_server只能运行在CLI模式下,所以不要试图通过浏览器进行访问,这样是无效的,我们在命令行下面执行,注意一定要找到php的绝对路径 /phpstudy/server/php/bin/php server.php (这行代码的意思是,把程序在服务器跑起来) 注意:我们平时执行完一个指令,执行完就结束了,但是现在的情况正好相反,当前程序一直处于执行中的状态,并没有退出终端。退出状态一般为当前终端的执行权交给了终端, 即可用在终端下进行其他操作,此时服务器的进程已经开启了。3>在开另一个终端,执行 telnet 127.0.0.1 9501 (模拟客户端请求) 如果没有安装telnet,可以 yum install -y telnet 安装4>创建客户端文件,也要在CLI下执行:client.php<?php// 创建一个同步阻塞的tcp socket// 第一个参数是表示socket的类型,有下面四种类型选择,这里选则tcp socket就好/** * SWOOLE_SOCK_TCP 创建tcp socketSWOOLE_SOCK_TCP6 创建tcp ipv6 socketSWOOLE_SOCK_UDP 创建udp socketSWOOLE_SOCK_UDP6 创建udp ipv6 socket */// 第二个参数是同步还是异步/** * SWOOLE_SOCK_SYNC 同步客户端SWOOLE_SOCK_ASYNC 异步客户端 */$client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_SYNC);// 随后建立连接,连接失败直接退出并打印错误码$client->connect('127.0.0.1', 9503) || exit("connect failed. Error: {$client->errCode}\n");// 向服务端发送数据$client->send("hello server.");// 从服务端接收数据$response = $client->recv();// 输出接受到的数据echo $response . PHP_EOL;// 关闭连接$client->close();5>/phpstudy/server/php/bin/php client.php //执行客户端,输出Server hello server.6>使用task异步处理数据 在建服务器程序 server_asy.php <?php/** * swoorl异步处理 */$serv = new swoole_server("127.0.0.1", 9503);//配置task进程的数量,即配置task_worker_num这个配置项。比如我们开启一个task进程$serv->set([ 'task_worker_num' => 1,]);$serv->on('Connect', function ($serv, $fd) { echo "new client connected." . PHP_EOL;});$serv->on('Receive', function ($serv, $fd, $fromId, $data) { echo "worker received data: {$data}" . PHP_EOL; // 投递一个任务到task进程中 $serv->task($data); // 通知客户端server收到数据了 $serv->send($fd, 'This is a message from server.'); // 为了校验task是否是异步的,这里和task进程内都输出内容,看看谁先输出 echo "worker continue run." . PHP_EOL;});/** * $serv swoole_server * $taskId 投递的任务id,因为task进程是由worker进程发起,所以多worker多task下,该值可能会相同 * $fromId 来自那个worker进程的id * $data 要投递的任务数据 */$serv->on('Task', function ($serv, $taskId, $fromId, $data) { echo "task start. --- from worker id: {$fromId}." . PHP_EOL; for ($i=0; $i < 5; $i++) { sleep(1); echo "task runing. --- {$i}" . PHP_EOL; } echo "task end." . PHP_EOL;});$serv->on('Finish', function ($serv, $taskId, $data) { echo "finish received data '{$data}'" . PHP_EOL;});$serv->start();7>/phpstudy/server/php/bin/php server_asy.php //执行服务器8>/phpstudy/server/php/bin/php client.php //在执行客户端9>再把server_asy.php中的echo"task end." . PHP_EOL; 改成return "task end." . PHP_EOL;,执行 /phpstudy/server/php/bin/php server_asy.php 和/phpstudy/server/php/bin/php client.php, 这时就可以看到swoole的异步请求成功了