swoole_process提供的setTimeOut用于设置管道读写操作的超时时间,其操作方式如下:
function swoole_process->setTimeout(double $timeout)
$timeout
单位为秒,支持浮点型,如1.5
表示1s
+500ms
- 设置成功返回
true
- 设置失败返回
false
,可使用swoole_errno
获取错误码
下面我们分析下其执行流程。
static PHP_METHOD(swoole_process, setTimeout)
{
double seconds;
//解析输入参数,这里输入的是超时时间,类型为double
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "d", &seconds) == FAILURE)
{
RETURN_FALSE;
}
swWorker *process = swoole_get_object(getThis());//获取内部封装对象
if (process->pipe == 0)//未设置管道信息,其实这个检查可以没有,这个设置超时时间,可以用在其他地方
{
swoole_php_fatal_error(E_WARNING, "no pipe, can not setTimeout the pipe.");
RETURN_FALSE;
}
SW_CHECK_RETURN(swSocket_set_timeout(process->pipe, seconds));//设置超时时间
}
int swSocket_set_timeout(int sock, double timeout)
{
int ret;
struct timeval timeo;//用于后续操作的时间封装对象
timeo.tv_sec = (int) timeout;//获取秒数信息
timeo.tv_usec = (int) ((timeout - timeo.tv_sec) * 1000 * 1000);//获取毫秒信息
ret = setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, (void *) &timeo, sizeof(timeo));//设置socket的发送超时时间
if (ret < 0)
{
swWarn("setsockopt(SO_SNDTIMEO) failed. Error: %s[%d]", strerror(errno), errno);
return SW_ERR;
}
ret = setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, (void *) &timeo, sizeof(timeo));//设置socket的接收超时时间
if (ret < 0)
{
swWarn("setsockopt(SO_RCVTIMEO) failed. Error: %s[%d]", strerror(errno), errno);
return SW_ERR;
}
return SW_OK;
}