资讯专栏INFORMATION COLUMN

PHP异步编程,异步的本质

lushan / 2254人阅读

摘要:实现异步的方式有哪些提供了一些异步方法那它们底层是用哪种方式实现的呢实现异步的方式有线程方式进程方式复用线程方式和进程方式类似有异步请求时开一个线程或者进程获取到数据后线程间可以直接共享数据进程间可以通过进程通信机制,如共享内存管道等方式进

实现异步的方式有哪些? swoole提供了一些异步方法, 那它们底层是用哪种方式实现的呢?

实现异步的方式有:

线程方式

进程方式

IO复用

线程方式和进程方式类似, 有异步请求时, 开一个线程或者进程, 获取到数据后, 线程间可以直接共享数据. 进程间可以通过进程通信机制,如共享内存,管道等方式进行数据传送. 思路很简单, 可以参考这篇利用swoole_process和eventloop实现php异步编程, 但是缺点非常明显, 开销太大, 一个异步请求,就要开一个线程或者进程.

IO复用方式, 通常有select,poll, epoll这几种方式, 当下最流行的当然是epoll, 性能好, 理论上来说没有连接限制, 单个进程内可以维持数十万的连接. 使用这种方式,当有异步请求时,可以在当前进程内,再开一个连接做异步请求,开销很少, 性能很好, 主流的异步实现都是这种方式.

swoole提供了一些异步http client, mysql client, 可以让你异步地访问http servermysql server, 通过回调的方式对返回的数据进行处理, 它们使用的方式就是IO复用.

来看一段swoole的源代码:

异步tcp请求

static int swClient_tcp_connect_async(swClient *cli, char *host, int port, double timeout, int nonblock)
{
    int ret;
    cli->timeout = timeout;

    //alloc input memory buffer
    cli->buffer = swString_new(cli->buffer_input_size);
    if (!cli->buffer)
    {
        return SW_ERR;
    }

    if (!(cli->onConnect && cli->onError && cli->onClose))
    {
        swWarn("onConnect/onError/onClose callback have not set.");
        return SW_ERR;
    }

    if (swClient_inet_addr(cli, host, port) < 0)
    {
        return SW_ERR;
    }

    while (1)
    {
        ret = connect(cli->socket->fd, (struct sockaddr *) &cli->server_addr.addr, cli->server_addr.len);
        if (ret < 0)
        {
            if (errno == EINTR)
            {
                continue;
            }
            SwooleG.error = errno;
        }
        break;
    }

    if ((ret < 0 && errno == EINPROGRESS) || ret == 0)
    {
        if (SwooleG.main_reactor->add(SwooleG.main_reactor, cli->socket->fd, cli->reactor_fdtype | SW_EVENT_WRITE) < 0)
        {
            return SW_ERR;
        }
        return SW_OK;
    }

    return ret;
}

关键看这一段:

if (SwooleG.main_reactor->add(SwooleG.main_reactor, cli->socket->fd, cli->reactor_fdtype | SW_EVENT_WRITE) < 0)
{
    return SW_ERR;
}
return SW_OK;

就是把socket fd放到reactor中监听, 本质上就是epoll, 也就是IO复用技术.

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/22792.html

相关文章

  • PHP socket初探 --- 关于IO一些枯燥理论

    摘要:原文地址要想更好了解编程,有一个不可绕过的环节就是在中,一切皆文件实际上要文件干啥不就是读写么所以,这句话本质就是才是王道用的打开文件关闭文件读读写写,这叫本地文件在编程中,本质就是网络所以,在开始进一步的编程前,我们必须先从概念上认识好 [原文地址:https://blog.ti-node.com/blog...] 要想更好了解socket编程,有一个不可绕过的环节就是IO.在Lin...

    sf190404 评论0 收藏0
  • 聊聊 2018 年后端技术趋势

    摘要:现在在后端业务开发编程方面,技术力量强的团队已经开始将技术栈从同步模式切换为异步了。使用这些技术方案是无法兼容已有程序的。影响了异步回调技术栈的普及。将会成为未来后端开发领域的主流技术方案。 今天太忙,少写一点,后面再补充。 异步模式 Go 语言越来越热门,很多大型互联网公司后端正在转向 GO 。Java 圈知名的服务化框架 Dubbo 也宣布转型异步模式。这是一个大趋势,异步模式已经...

    Miyang 评论0 收藏0
  • 彻底搞清 同步,异步,阻塞,非阻塞概念性知识

    摘要:需要先对的概念有一定的认识我们通常使用的打开文件关闭文件读读写写这叫本地文件而在编程中本质其实是网络同步异步阻塞非阻塞之前反正一直搞不清楚同步和阻塞异步和非阻塞的概念总感觉同步就是阻塞异步就是非阻塞的总是搞得晕乎乎的于是就重新查了些资料进行 IO 需要先对 IO 的概念有一定的认识: 我们通常使用php的fopen打开文件关闭文件读读写写, 这叫本地文件IO; 而在socket编程中...

    libin19890520 评论0 收藏0
  • 函数式编程与面向对象编程[5]:编程本质

    摘要:函数式编程与面向对象编程编程的本质之剑目录编程的本质读到两篇文章写的不错综合摘录一下复合是编程的本质函数式程序员在洞察问题方面会遵循一个奇特的路线。在面向对象编程中,类或接口的声明就是表面。 函数式编程与面向对象编程[5]:编程的本质 之剑 2016.5.6 01:26:31 编程的本质 读到两篇文章,写的不错, 综合摘录一下 复合是编程的本质 函数式程序员在洞察问题方面会遵循...

    miracledan 评论0 收藏0
  • PHP并发IO编程之路

    摘要:下文如无特殊声明将使用进程同时表示进程线程。收到数据后服务器程序进行处理然后使用向客户端发送响应。现在各种高并发异步的服务器程序都是基于实现的,比如。 并发 IO 问题一直是服务器端编程中的技术难题,从最早的同步阻塞直接 Fork 进程,到 Worker 进程池/线程池,到现在的异步IO、协程。PHP 程序员因为有强大的 LAMP 框架,对这类底层方面的知识知之甚少,本文目的就是详细介...

    Riddler 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<