美文网首页php
PHP多线程编程和非阻塞实现方法

PHP多线程编程和非阻塞实现方法

作者: liamu | 来源:发表于2018-07-14 19:41 被阅读530次

PHP多线程


线程概述

线程是操作系统能够进行调度的最小单位

  • 一个多线程程序比单线程程序被操作系统调度的概率更大,所以多线程程序一般会比单线程程序更高效;
  • 多线程程序的多个线程可以在多核 CPU 的多个核心同时运行,可以将完全发挥机器多核的优势;
  • 线程的创建和切换的系统开销都比进程要小,所以一定程度上会比多进程更高效;
  • 线程天生的共享内存空间,线程间的通信更简单,避免了进程IPC引入新的复杂度。
什么时候该使用线程
  • I/O 阻塞会使操作系统发生任务调度,阻塞当前任务,所以代码中 I/O 多的情况下,使用多线程时可以将代码并行
  • 多线程能充分利用 CPU,所以有多处大计算量代码时,也可以使用多线程使他们并行执行
用线程的好与坏
  • PHP 实现的线程安全主要是使用 TSRM 机制对 全局变量和静态变量进行了隔离,将全局变量和静态变量 给每个线程都复制了一份,各线程使用的都是主线程的一个备份,从而避免了变量冲突,也就不会出现线程安全问题。
  • 子线程一旦开始运行,主线程便无法再对子线程运行细节进行调整
扩展安装

PHP 默认并不支持多线程,要使用多线程需要安装 pthread 扩展,而要安装 pthread 扩展,必须使用 --enable-maintainer-zts 参数重新编译 PHP,这个参数是指定编译 PHP 时使用线程安全方式。

./configure --enable-maintainer-zts --with-tsrm-pthreads

实例
class Request extends Thread {
    public $url;
    public $response;
    public function __construct($url) {
        $this->url = $url;
    }
    public function run() {
        $this->response = file_get_contents($this->url);
    }
}
$chG = new Request("www.google.com");
$chB = new Request("www.baidu.com");
$chG ->start();
$chB ->start();
$chG->join();
$chB->join();

$gl = $chG->response;
$bd = $chB->response;

PHP非阻塞

  • 使用 fastcgi_finish_request()
echo "program start...";
fastcgi_finish_request();

sleep(1);
echo 'debug1...';

sleep(10);
echo 'debug2...';
  • 使用 fsockopen()
    stream_set_blocking()

  • 使用 cURL
    $cmh = curl_multi_init();

  • 使用 Gearman/Swoole 扩展

  • 使用缓存和队列
    redis

  • 调用系统命令
    $cmd = 'nohup php ./processd.php $someVar >/dev/null &';

  • 使用 pcntl_fork()

  • PHP 原生支持
    yield

相关文章

  • PHP多线程编程和非阻塞实现方法

    PHP多线程 线程概述 线程是操作系统能够进行调度的最小单位 一个多线程程序比单线程程序被操作系统调度的概率更大,...

  • 9.8动态语言层并发处理视频

    相关概念什么是进程、线程、协程什么是多进程、多线程同步阻塞模型异步非阻塞模型PHP并发编程实践 进程是一个“执行中...

  • PHP非阻塞实现方法

    转自https://www.awaimai.com/660.html 为让 PHP 在后端处理长时间任务时不阻塞,...

  • 多线程——Future和Callable

    在并发编程中,我们经常用到非阻塞的模型,在之前的多线程的三种实现中,不管是继承Thread类还是实现Runnabl...

  • python-多线程编程

    串行程序必须使用非阻塞I/O,或拥有计时器的阻塞I/O,需兼顾要执行的多个任务,难以维护。 多线程编程,以及多线程...

  • 线程进程

    多线程 多进程 协程的异同点 同步异步阻塞和非阻塞的概念 计算密集型任务和IO密集型任务 分布式编程: 同步原语 ...

  • Java如何实现延时访问

    调用某个方法后,我们需要程序过一段时间再去处理,就可以用多线程阻塞或Timer定时器来实现 方法一 多线程阻塞实现...

  • 并发编程之并发队列

    常见的并发队列有2种:阻塞队列和非阻塞队列。阻塞队列使用锁实现,非阻塞队列使用CAS非阻塞算法实现。这2种队列都是...

  • 并发队列-无界非阻塞队列ConcurrentLinkedQueu

    一、 前言 常用的并发队列有阻塞队列和非阻塞队列,前者使用锁实现,后者则使用CAS非阻塞算法实现,使用非阻塞队列一...

  • 为什么非阻塞网络编程中应用层Buffer是必须的?

    为什么非阻塞网络编程中应用层Buffer是必须的? 在 陈硕的《Linux 多线程服务端编程》中一书提到:为什么非...

网友评论

    本文标题:PHP多线程编程和非阻塞实现方法

    本文链接:https://www.haomeiwen.com/subject/pfnypftx.html