本文章于2013年11月修改。
swoole已使用C重写作为PHP扩展来运行。项目地址:https://github.com/matyhtf/swoole
swoole提供了PHP的高性能Server,异步IO,AsyncMySQL等特性。
原PHP代码框架迁移至https://github.com/matyhtf/swoole_framework。保留原有代码和web框架。
--------------------------------------------------------------------------------------------------
Swoole Socket网络开发框架,是基于php的libevent和pcntl模块的,并且只能用于Linux/Unix系统下。请先启用pcntl,安装libevent扩展。
pcntl:PHP核心模块已包含了pcntl,只需在编译时加入--enable-pcntl即可,当然也可以用extension扩展
libevent:http://pecl.php.net/package/libevent
编写的类需要继承自TCPServer类,在SwooleSocket包中。目前只提供了单进程异步事件模型,适合用于IO耗时较少的网络服务器程序,比如聊天室。多进程异步模型,多进程同步模型,会在近期提供。基类的代码,请从http://code.google.com/p/swoole/检出
<?php require 'TCPServer.php'; class MyServer extends TCPServer { function onRecive($client_id,$data) { $data = trim($data); if($data=="quit") { $this->close($client_id); return true; } elseif($data=='shutdown') { $this->shutdown(); } else { $client_socket_name = stream_socket_get_name($this->client_sock[$client_id],true); echo "Server send response data to client $client_socket_name\n"; $send = date('Y-m-d H:i:s')."$client_socket_name said:$data\n"; $this->sendAll($client_id,$send); } } /** * 发送到所有客户端 * @param $data * @return unknown_type */ function sendAll($client_id,$data) { foreach($this->client_sock as $k=>$sock) { if($k==$client_id) continue; fwrite($sock,$data); } } /** * 发送到某个客户端 * @param $client_id * @param $data * @return unknown_type */ function sendTo($client_id,$data) { fwrite($this->client_sock[$client_id],$data); } function onStart() { echo "Server in running!\n"; } function onConnect($client_id) { $this->sendAll($client_id,"Client $client_id is connected!\n"); } function onClose($client_id) { $this->sendAll($client_id,"Client $client_id is closed!\n"); } function onShutdown() { echo "Server in stop!\n"; } } $server = new MyServer('0.0.0.0',8005); $server->run();
客户端程序
<?php class Stdio { static $in; static $out; static $buffer_size = 1024; static function input($h='') { if(!self::$in) self::$in = fopen('php://stdin','r'); if($h) self::output($h); return trim(fread(self::$in,self::$buffer_size)); } static function output($string) { if(!self::$out) self::$out = fopen('php://stdout','w'); return fwrite(self::$out,$string); } } $fp = stream_socket_client('tcp://127.0.0.1:8005',$errno, $errstr); $socket = serialize($fp); if(!$fp) { echo "ERROR: $errno - $errstr<br />\n"; } else { $pid = pcntl_fork(); if($pid==-1) { exit("fork fail!\n"); } //child elseif($pid==0) { var_dump($socket); $fp2 = unserialize($socket); while(!feof($fp2)) { Stdio::output(fgets($fp2, 1024)); } } //parent else { while($string!=="quit") { if(!is_writable($fp)) break; $string = Stdio::input("qq#"); fwrite($fp,$string); } posix_kill($pid, 9); } fclose($fp); }
php tcpserver.php 运行服务器程序
php tcpclient.php 运行客户端程序,客户端有2个进程,主进程负责接收输入信息,发送到网络。另一个进程,接收网络信息,显示在屏幕上。
相关推荐
Memcached与Libevent结合使用,可以构建出高并发、低延迟的Web服务。例如,一个基于Libevent的服务器可以监听客户端的请求,当请求到达时,服务器从Memcached中快速获取数据,然后返回给客户端,从而避免了直接查询...
对于PHP开发者而言,使用`libevent`可以通过扩展来实现异步IO操作,从而提升应用程序的性能。本文将详细介绍如何在系统上安装`libevent`库及其PHP扩展。 #### 二、安装libevent **步骤1:下载libevent** 首先,...
- PHP在处理高并发网络请求时,可以利用libevent实现异步非阻塞I/O,提升性能。例如,通过pecl扩展libevent到PHP中,创建事件基础结构,监听socket事件。 - 使用`libevent_event_new`创建事件,`libevent_event_...
Workerman是一款基于PHP开发的高性能、高并发的TCP/UDP/HTTP服务器框架,适用于构建长期运行的服务,如WebSocket服务、TCP服务、HTTP服务等。它为PHP开发者提供了一个无需依赖其他运行环境(如Apache或Nginx)就能...
ReactPHP是一个基于libevent和libev的PHP异步I/O库,可以构建非阻塞的网络应用。通过EventLoop,你可以监听各种事件,包括网络连接、文件描述符等,实现异步处理。 总的来说,PHP异步执行的方法多种多样,具体选择...
《深入理解基于PHP的Workerman高性能PHP Socket服务器框架》 在现代互联网开发中,服务器性能是决定应用响应速度和用户体验的关键因素之一。PHP作为一种广泛使用的脚本语言,一直以来以其便捷性和灵活性深受开发者...
PHP的libevent扩展使得PHP可以直接调用libevent的接口,实现非阻塞I/O和异步处理。这在开发WebSocket服务器、长连接服务等高并发场景下非常有用。 2. PHP7与event库的结合: event扩展为PHP7提供了与event库交互...
- **传统PHP的限制**:传统的PHP基于同步模型运行,每个HTTP请求都需要等待前一个请求完成后才能继续执行,这导致了在高并发场景下的性能瓶颈。 - **异步编程的概念**:异步编程允许程序在等待某些操作(如数据库...
在PHP中实现一对多的socket通信,通常会涉及到网络编程和并发处理,这对于构建服务器端应用,特别是需要处理大量客户端连接的应用来说至...结合libevent的底层性能优化,这样的解决方案特别适合高并发的网络服务场景。
libevent 的核心在于其事件模型,它允许开发者编写非阻塞的、高并发的网络服务器。这种事件驱动的编程方式使得程序能够高效地处理大量并发连接,而无需为每个连接创建独立的线程或进程。通过注册事件处理器,...
libevent提供了多种事件机制,如epoll、kqueue等,可以高效地处理大量并发连接,非常适合构建高并发的网络服务器。在PHP中结合libevent,开发者可以轻松实现异步非阻塞I/O,提高服务器的吞吐量和响应速度。
异步Web框架是一种用于构建高性能、高并发网络应用的编程模型。在传统的Web框架中,服务器通常采用同步I/O处理模式,即每个请求都会阻塞一个线程,直到响应完成。这种方式在面对高并发场景时,可能会导致大量线程被...
1. **异步非阻塞I/O**:Swoole利用epoll(Linux)和kqueue(FreeBSD)等事件驱动模型,实现I/O操作的异步非阻塞,提高了服务器处理高并发请求的能力。 2. **协程(Coroutine)**:Swoole在PHP7中引入了协程支持,...
它基于libevent库,利用异步非阻塞I/O来提高服务器性能,尤其适合处理大量并发连接。Zevent通过监听套接字上的事件,例如连接请求、数据读写、连接关闭等,只在有实际活动时唤醒工作线程,降低了CPU的空转率。 在...
它采用事件驱动、异步非阻塞的方式处理请求,基于libevent或libuv库,能够充分利用多核CPU资源,实现高并发处理。Workerman支持TCP、UDP和HTTP等多种协议,并且可以自定义协议,这使得它非常灵活,可以适应各种服务...
在实际应用中,理解并熟练掌握这些概念和技术,可以有效地利用PHP处理复杂的Web服务场景,特别是在高并发和高性能需求的项目中。通过合理地设计进程间的协作模式,可以提高系统的响应速度和资源利用率,为用户提供更...
1. **异步非阻塞**:Workerman采用事件驱动模型,基于libevent库(或它的PHP封装pecl-event扩展)实现异步非阻塞I/O,能够处理大量并发连接,提高系统的吞吐量。 2. **多进程/线程模型**:Workerman支持多进程和多...
在Web开发中,ReactPHP常被用来创建实时、高并发的服务器端应用。 Symfony是一个流行的PHP框架,主要用于构建复杂的企业级Web应用。它提供了一整套工具和服务,包括依赖注入、路由、模板引擎、安全管理和ORM等,以...
Workerman提供了进程管理、任务调度、并发处理等功能,使得PHP可以处理高并发的网络请求,不再局限于Web应用。 2. **事件驱动与异步编程**:Workerman基于事件驱动模型,采用libevent或ReactPHP等库来实现异步I/O...
由于它使用了libevent和Epoll事件模型,因此在处理大量并发连接时表现出色,尤其适合构建高并发的网络服务。 2. **PHP异步编程**: PHP传统上是一种同步编程语言,但Workerman引入了异步编程的概念,通过非阻塞I/O...