在这里简述swoole两种API编写简单HTTP服务器。
使用swoole_server API,构建HTTP服务器,4个步骤:
直接代码体现,新建server.php:
set(array(
'worker_num' => 8,
'daemonize' => 0,
'max_request' => 10000,
'dispatch_mode' => 2,
'debug_mode'=> 1,
));
//3.注册事件回调函数
$serv->on('Receive', function($serv, $fd, $from_id, $data){
$respData='Hello Swoole.
';
response($serv,$fd,$respData);//封装并发送HTTP响应报文
});
//4.启动服务器
$serv->start();
如何封装HTTP响应报文?首先你得知道HTTP响应报文的组成结构,如下图
知道了响应报文的组成结构,那我的响应报文应该是这样的:
HTTP/1.1 200
Server:SwooleServer
Content-Type:text/html;charset=utf8
Content-Length:13
Hello Swoole.
代码实现。
/**
* 发送内容
* @param \swoole_server $serv
* @param int $fd
* @param string $respData
* @return void
*/
function response($serv,$fd,$respData){
//响应行
$response = array(
'HTTP/1.1 200',
);
//响应头
$headers = array(
'Server'=>'SwooleServer',
'Content-Type'=>'text/html;charset=utf8',
'Content-Length'=>strlen($respData),
);
foreach($headers as $key=>$val){
$response[] = $key.':'.$val;
}
//空行
$response[] = '';
//响应体
$response[] = $respData;
$send_data = join("\r\n",$response);
$serv->send($fd, $send_data);
}
到此,一个简单响应Hello Swoole.的HTTP服务器就完成了。完整代码:这里
(访问不了gist?配置本地hosts文件: 192.30.252.141 gist.github.com )
运行 php server.php
,浏览器访问http://127.0.0.1:9501/,当然我们常常使用Nginx作为前端代理,设一个测试域名www.server.com,本地设置hosts映射,就能通过域名来访问了。Nginx配置:这里
注意:当响应报文格式不正确时,浏览器页面会一直转菊花,等待请求返回...
再后来,有了swoole_http_server,HTTP服务器代码就变得更加简单了!
on('request', function ($request, $response) {
$html = "Hello Swoole.
";
$response->end($html);
});
没错,就这几行代码就实现了。不再需要封装响应报文。swoole_http_server 继承于 swoole_server,是swoole内置Http服务器的支持,通过几行代码即可写出一个异步非阻塞多进程的Http服务器。
Notice:swoole_http_server对Http协议的支持并不完整,建议仅作为应用服务器。并且在前端增加Nginx作为代理