swoole_server_set()
swoole_server_set(\swoole_server $serv, $arguments)
swoole_server_set函数用于设置swoole_server运行时的各项参数
Parameters
\swoole_server | $serv | |
$arguments |
Swoole Develop Structure
Swoole 结构,便于开发过程中查看文档,以及屏蔽IDE undefined 提示,便于快速查看函数用法。
本文件使用方式
普通IDE: 开发Swoole项目同时,在IDE中打开/导入本文件即可。 如果IDE自带 Include Path 功能(如:PhpStorm),设置该文件路径即可。
PhpStorm 另一种方法:
WinRAR打开
PS:替换前请备份php.jar 若发生错误便于恢复 :)
Author:EagleWu eaglewudi@gmail.com Date: 2014/01/17
swoole_http_client | swoole_http_client |
swoole_http_request | Http请求对象 Class swoole_http_request |
swoole_http_response | Http响应对象 Class swoole_http_response |
swoole_http_server | Class swoole_http_server |
swoole_atomic | Class swoole_atomic |
swoole_buffer | Class swoole_buffer |
swoole_client | swoole_client |
swoole_server | Class swoole_server |
swoole_lock | Class swoole_lock |
swoole_redis | 异步Redis客户端 |
swoole_process | swoole进程管理类 内置IPC通信支持,子进程和主进程之间可以方便的通信 支持标准输入输出重定向,子进程内echo,会发送到管道中,而不是输出屏幕 |
swoole_table | 内存表 |
swoole_channel | Class swoole_channel |
swoole_redis_server | Redis服务器端 |
swoole_websocket_server | Class swoole_http_server |
swoole_websocket_frame | |
swoole_mysql | Class Mysql |
swoole_http2_client | |
swoole_mysql_exception | |
swoole_serialize | swoole的二进制序列化库 序列化后的结果为二进制格式,只适合机器读取,不适合人读 序列化性能更高,可节省大量CPU资源,基准测试中序列化和反序列化耗时为PHP官方serialize的40% 序列化后的结果数据尺寸更小,可节省内存资源,基准测试中序列化结果尺寸为PHP官方serialize的50% |
Co | Class Co Coroutine的短名API |
Chan | Class Channel |
swoole_server_set(\swoole_server $serv, $arguments)
swoole_server_set函数用于设置swoole_server运行时的各项参数
\swoole_server | $serv | |
$arguments |
swoole_server_create(string $host, integer $port, integer $mode = SWOOLE_PROCESS, integer $sock_type = SWOOLE_SOCK_TCP)
创建一个swoole server资源对象
string | $host | 参数用来指定监听的ip地址,如127.0.0.1,或者外网地址,或者0.0.0.0监听全部地址 |
integer | $port | 监听的端口,如9501,监听小于1024端口需要root权限,如果此端口被占用server-start时会失败 |
integer | $mode | 运行的模式,swoole提供了3种运行模式,默认为多进程模式 |
integer | $sock_type | 指定socket的类型,支持TCP/UDP、TCP6/UDP64种 |
swoole_server_addlisten(\swoole_server $serv, string $host = '127.0.0.1', integer $port = 9502) : void
增加监听的端口
您可以混合使用UDP/TCP,同时监听内网和外网端口 业务代码中可以通过调用swoole_connection_info来获取某个连接来自于哪个端口
\swoole_server | $serv | |
string | $host | |
integer | $port |
swoole_server_addtimer(\swoole_server $serv, integer $interval) : boolean
设置定时器
第二个参数是定时器的间隔时间,单位为毫秒。 swoole定时器的最小颗粒是1毫秒,支持多个定时器。 此函数可以用于worker进程中。或者通过swoole_server_set设置timer_interval来调整定时器最小间隔。
增加定时器后需要为Server设置onTimer回调函数,否则会造成严重错误。 多个定时器都会回调此函数。 在这个函数内需要自行switch,根据interval的值来判断是来自于哪个定时器。
\swoole_server | $serv | |
integer | $interval |
swoole_server_handler(\swoole_server $serv, string $event_name, callable $event_callback_function) : boolean
设置Server的事件回调函数
第一个参数是swoole的资源对象 第二个参数是回调的名称, 大小写不敏感,具体内容参考回调函数列表 第三个函数是回调的PHP函数,可以是字符串,数组,匿名函数。
设置成功后返回true。如果$event_name填写错误将返回false。
onConnect/onClose/onReceive 这3个回调函数必须设置,其他事件回调函数可选。 如果设定了timer定时器,onTimer事件回调函数也必须设置
\swoole_server | $serv | |
string | $event_name | |
callable | $event_callback_function |
swoole_server_start(\swoole_server $serv) : boolean
启动server,监听所有TCP/UDP端口
启动成功后会创建worker_num+2个进程。主进程+Manager进程+n*Worker进程。 启动失败扩展内会抛出致命错误,请检查php error_log的相关信息。errno={number}是标准的Linux Errno,可参考相关文档。 如果开启了log_file设置,信息会打印到指定的Log文件中。
如果想要在开机启动时,自动运行你的Server,可以在/etc/rc.local文件中加入:
/usr/bin/php /data/webroot/www.swoole.com/server.php
常见的错误有及拍错方法:
1、bind端口失败,原因是其他进程已占用了此端口 2、未设置必选回调函数,启动失败 3、php有代码致命错误,请检查php的错误信息 4、执行ulimit -c unlimited,打开core dump,查看是否有段错误 5、关闭daemonize,关闭log,使错误信息可以打印到屏幕
\swoole_server | $serv |
swoole_server_reload(\swoole_server $serv) : void
平滑重启Server
一台繁忙的后端服务器随时都在处理请求,如果管理员通过kill进程方式来终止/重启服务器程序,可能导致刚好代码执行到一半终止。 这种情况下会产生数据的不一致。如交易系统中,支付逻辑的下一段是发货,假设在支付逻辑之后进程被终止了。 会导致用户支付了货币,但并没有发货,后果非常严重。
Swoole提供了柔性终止/重启的机制,管理员只需要向SwooleServer发送特定的信号,Server的worker进程可以安全的结束。
SIGTREM: 向主进程发送此信号服务器将安全终止 SIGUSR1: 向管理进程发送SIGUSR1信号,将平稳地restart所有worker进程,在PHP代码中可以调用swoole_server_reload($serv)完成此操作
\swoole_server | $serv |
swoole_server_close(\swoole_server $serv, integer $fd, integer $from_id) : boolean
关闭客户端连接
Server主动close连接,也一样会触发onClose事件。 不要在close之后写清理逻辑,应当放置到onClose回调中处理。
\swoole_server | $serv | |
integer | $fd | |
integer | $from_id |
swoole_server_send(\swoole_server $serv, integer $fd, string $data, integer $from_id) : boolean
向客户端发送数据
$data的长度可以是任意的。扩展函数内会进行切分。 如果是UDP协议,会直接在worker进程内发送数据包。 发送成功会返回true,如果连接已被关闭或发送失败会返回false.
\swoole_server | $serv | |
integer | $fd | |
string | $data | |
integer | $from_id |
swoole_connection_info(\swoole_server $serv, integer $fd) : array
获取客户端连接的信息
返回数组含义: from_id 来自哪个poll线程 from_fd 来自哪个server socket from_port 来自哪个Server端口 remote_port 客户端连接的端口 remote_ip 客户端连接的ip
以下 v1.6.10 增加 connect_time 连接时间 last_time 最后一次发送数据的时间
\swoole_server | $serv | |
integer | $fd |
on success or false on failure.
swoole_connection_list(\swoole_server $serv, integer $start_fd, integer $pagesize = 10) : array
遍历当前Server所有的客户端连接
此函数接受3个参数,第一个参数是server的资源对象,第二个参数是起始fd,第三个参数是每页取多少条,最大不得超过100。 调用成功将返回一个数字索引数组,元素是取到的$fd。 数组会按从小到大排序,最后一个$fd作为新的start_fd再次尝试获取。
\swoole_server | $serv | |
integer | $start_fd | |
integer | $pagesize |
on success or false on failure
swoole_event_add(integer $sock, $read_callback = null, $write_callback = null, $flag = null) : boolean
将Socket加入到swoole的reactor事件监听中
此函数可以用在Server或Client模式下
参数1为socket的文件描述符; 参数2为回调函数,可以是字符串函数名、对象+方法、类静态方法或匿名函数,当此socket可读是回调制定的函数。
Server程序中会增加到server socket的reactor中。 Client程序中,如果是第一次调用此函数会自动创建一个reactor,并添加此socket,程序将在此处进行wait。 swoole_event_add函数之后的代码不会执行。当调用swoole_event_exit才会停止wait,程序继续向下执行。 第二次调用只增加此socket到reactor中,开始监听事件
integer | $sock | |
$read_callback | ||
$write_callback | ||
$flag |
swoole_server_task(\swoole_server $serv, string $data) : integer
投递异步任务到task_worker池中
此函数会立即返回,worker进程可以继续处理新的请求。 此功能用于将慢速的任务异步地去执行,比如一个聊天室服务器,可以用它来进行发送广播。 当任务完成时,在task_worker中调用swoole_server_finish($serv, "finish"); 告诉worker进程此任务已完成。当然swoole_server_finish是可选的。
发送的$data必须为字符串,如果是数组或对象,请在业务代码中进行serialize处理,并在onTask/onFinish中进行unserialize。 $data可以为二进制数据,最大长度为8K。字符串可以使用gzip进行压缩。
使用swoole_server_task必须为Server设置onTask和onFinish回调, 否则swoole_server_start会失败。此回调函数会在task_worker进程中被调用。
函数会返回一个$task_id数字,表示此任务的ID。如果有finish回应,onFinish回调中会携带$task_id参数。
task_worker的数量在swoole_server_set参数中调整,如task_worker_num => 64,表示启动64个进程来接收异步任务。 swoole_server_task和swoole_server_finish可发送$data的长度最大不得超过8K,此参数受SW_BUFFER_SIZE宏控制。
\swoole_server | $serv | |
string | $data |
$task_id
swoole_server_finish(\swoole_server $serv, string $response) : void
task_worker进程中通知worker进程,投递的任务已完成
此函数可以传递结果数据给worker进程 使用swoole_server_finish函数必须为Server设置onFinish回调函数。此函数只可用于task_worker进程的onTask回调中 swoole_server_finish是可选的。如果worker进程不关心任务执行的结果,可以不调用此函数
\swoole_server | $serv | |
string | $response |
swoole_server_deltimer(\swoole_server $serv, integer $interval) : void
删除定时器
$interval 参数为定时器的间隔时间 根据定时器时间区分不同的定时器
\swoole_server | $serv | |
integer | $interval |
swoole_server_shutdown(\swoole_server $serv) : void
关闭服务器
此函数可以用在worker进程内。
\swoole_server | $serv |
swoole_server_taskwait(string $task_data, float $timeout = 0.5) : string
投递堵塞任务到task进程池
taskwait与task方法作用相同,用于投递一个异步的任务到task进程池去执行。 与task不同的是taskwait是阻塞等待的,直到任务完成或者超时返回。 $result为任务执行的结果,由$serv->finish函数发出。如果此任务超时,这里会返回false。
taskwait是阻塞接口,如果你的Server是全异步的请不要使用它
string | $task_data | |
float | $timeout |
swoole_async_readfile(string $filename, mixed $callback)
异步读取文件内容 此函数调用后会马上返回,当文件读取完毕时会回调制定的callback函数。 callback( $filename, $content )
swoole_async_readfile会将文件内容全部复制到内存,所以不能用于大文件的读取 如果要读取超大文件,请使用swoole_async_read函数 swoole_async_readfile最大可读取4M的文件,受限于SW_AIO_MAX_FILESIZE宏
string | $filename | |
mixed | $callback |
swoole_async_writefile(string $filename, string $content, callback $callback, integer $flags)
异步写文件,调用此函数后会立即返回, 当写入完成时会自动回调指定的callback函数 callback($filename)
swoole_async_writefile最大可写入4M的文件 swoole_async_writefile可以不指定回调函数
string | $filename | |
string | $content | |
callback | $callback | |
integer | $flags | (在 1.9.1 或更高版本可用) |
swoole_async_read(string $filename, mixed $callback, integer $trunk_size = 8192, integer $offset) : boolean
异步读文件
使用此函数读取文件是非阻塞的,当读操作完成时会自动回调制定的函数 此函数与swoole_async_readfile不同,它是分段读取,可以用于读取超大文件。 每次只读 $trunk_size 个字节,不会占用太多内存
callback($filename, $content) callback函数,可以通过return true/false,来控制是否继续读下一个trunk return true,继续读取 return false,停止读取并关闭文件
string | $filename | |
mixed | $callback | |
integer | $trunk_size | |
integer | $offset | (在 1.7.13 或更高版本可用) |
swoole_async_write(string $filename, string $content, integer $offset = -1, mixed $callback = null) : boolean
异步写文件
与swoole_async_writefile不同,write是分段读写的。 不需要一次性将要写的内容放到内存里,所以只占用少量内存。 swoole_async_write通过传入的offset参数来确定写入的位置
callback($filename)
string | $filename | |
string | $content | |
integer | $offset | |
mixed | $callback |
swoole_client_select(array $read, array $write, array $error, float $timeout) : integer
IO事件循环
swoole_client的并行处理中用了select来做IO事件循环。为什么要用select呢? 因为client一般不会有太多连接,而且大部分socket会很快接收到响应数据。 在少量连接的情况下select比epoll性能更好,另外select更简单。
$read,$write,$error分别是可读/可写/错误的文件描述符。 这3个参数必须是数组变量的引用。数组的元素必须为swoole_client对象。 $timeout参数是select的超时时间,单位为秒,接受浮点数。
调用成功后,会返回事件的数量,并修改$read/$write/$error数组。 使用foreach遍历数组,然后执行$item->recv/$item->send来收发数据。 或者调用$item->close()或unset($item)来关闭socket。
array | $read | 可读 |
array | $write | 可写 |
array | $error | 错误 |
float | $timeout |