ホームページ  >  記事  >  バックエンド開発  >  詳細な説明: pthreads PHP を使用して、PHP でのマルチスレッドの使用を拡張する

詳細な説明: pthreads PHP を使用して、PHP でのマルチスレッドの使用を拡張する

WBOY
WBOYオリジナル
2016-06-13 12:05:03974ブラウズ

詳細な説明: 真のマルチスレッドを実現するには、PHP に pthreads PHP 拡張機能を使用します

PHP 5.3 以降では、pthreads PHP 拡張機能を使用すると、PHP が真にマルチスレッドをサポートできるようになります。マルチスレッドにより、繰り返しの周期的なタスクを処理する際のプログラムの実行時間を大幅に短縮できます。

前回の記事で、ほとんどの Web サイトのパフォーマンスのボトルネックは PHP サーバーにあるわけではないと言いました。サーバーまたは CPU コアの数を水平方向に (さまざまなクラウド ホストに対して) 増やすだけで簡単に対処できるからです。 VPS または CPU コアの数を増やす方が便利です。バックアップ イメージを使用して VPS を直接追加できます。オペレーティング システムや環境をインストールして構成する必要さえありません。代わりに、MySQL データベースに依存します。 MySQL データベースと結合クエリ SQL を使用する場合は、ビジネス ロジックを処理できる可能性がありますが、大量の同時リクエストが発生すると、作業が停止します。 NoSQL データベースを使用する場合、同じビジネス ロジックを処理するのに 10 個のクエリが必要になる可能性がありますが、各クエリは MySQL よりも高速です。10 ループの NoSQL クエリは、1 秒あたり数万回処理できる MySQL 結合クエリよりも高速である可能性があります。 . クエリはまったく問題ありません。 PHP マルチスレッドを追加し、同時に 10 個のスレッドで NoSQL をクエリし、結果の概要出力を返すと、速度が速くなります。実際の APP 製品では、ユーザーの好みに基づいてリアルタイムで製品を推奨する PHP インターフェイスを呼び出します。PHP は、ユーザーのパーソナライズされた製品データをリアルタイムで計算するために、BigSea NoSQL データベースに対して 500 ~ 1,000 のクエリを開始する必要があります。 PHP のマルチスレッドは非常に明白です。

PHP 拡張機能のダウンロード: https://github.com/krakjoe/pthreads
PHP マニュアル文書: http://php.net/manual/zh/book.pthreads.php

1. 拡張コンパイルとインストール (Linux)、編集パラメーター --enable-maintainer-zts が必要です:

cd /Data/tgz/php-5.5.1
./configure --prefix =/Data/apps/php --with-config-file-path=/Data/apps/php/etc --with-mysql=/Data/apps/mysql --with-mysqli=/Data/apps/mysql/ bin/mysql_config --with-iconv-dir --with-freetype-dir=/データ/apps/libs --with-jpeg-dir=/データ/apps/libs --with-png-dir=/データ/apps /libs --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization - -with-curl --enable-mbregex --enable-fpm --enable-mbstring --with-mcrypt=/Data/apps/libs --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --enable-opcache --with-pdo-mysql --enable-maintainer-zts
make clean
make
make install??????

unzip pthreads-master.zip
cd pthreads-master
/Data/apps/php/ bin/ phpize
./configure --with-php-config=/Data/apps/php/bin/php-config
make
make install


vi /Data/apps/php/etc/php.ini


追加:

extension = "pthreads.so"


2. PHP マルチスレッドと For ループを指定して、Baidu 検索ページの PHP コード例をキャプチャします:

?

? class test_thread_run extends Thread?
? {
? ? ? public $url;
? ? ? public $data;


? ? ?パブリック関数 __construct($url)
? ? ? {
? ? ? ? ? $this->url = $url;
? ? ? }


? ? ?パブリック関数 run()
? ? ? {
? ? ? ? ? if(($url = $this->url))
? ? ? ? ? {
? ? ? ? ? ? ? $this->data = model_http_curl_get($url);
? ? ? ? ? }
? ? ? }
? }


? function model_thread_result_get($urls_array)?
? {
? ? ? foreach ($urls_array as $key => $value)?
? ? ? {
? ? ? ? ? $thread_array[$key] = 新しい test_thread_run($value["url"]);
? ? ? ? ? $thread_array[$key]->start();
? ? ? }


? ? ? foreach ($thread_array as $thread_array_key => $thread_array_value)?
? ? ? {
? ? ? ? ? while($thread_array[$thread_array_key]->isRunning())
? ? ? ? ? {
? ? ? ? ? ? ? usleep(10);
? ? ? ? ? }
? ? ? ? ? if($thread_array[$thread_array_key]->join())
? ? ? ? ? {
? ? ? ? ? ? ? $variable_data[$thread_array_key] = $thread_array[$thread_array_key]->data;
? ? ? ? ? }
? ? ? }
? ? ? $variable_data を返す;
? }


? function model_http_curl_get($url,$userAgent="")?
? {
? ? ? $userAgent = $userAgent ? $userAgent : 'Mozilla/4.0 (互換性; MSIE 7.0; Windows NT 5.2)';?
? ? ? $curl =curl_init();
? ? ? curl_setopt($curl, CURLOPT_URL, $url);
? ? ? curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
? ? ? curl_setopt($curl, CURLOPT_TIMEOUT, 5);
? ? ? curl_setopt($curl, CURLOPT_USERAGENT, $userAgent);
? ? ? $result =curl_exec($curl);
? ? ? curl_close($curl);
? ? ? return $result;
? }


? for ($i=0; $i ? {?
? ? ? $urls_array[] = array("name" => "baidu", "url" => "http://www.baidu.com/s?wd=".mt_rand(10000,20000));
? }


? $t = microtime(true);
? $result = model_thread_result_get($urls_array);
? $e = microtime(true);
? echo "多線程:".($e-$t)."n";


? $t = microtime(true);
? foreach ($urls_array as $key => $value)?
? {
? ? ? $result_new[$key] = model_http_curl_get($value["url"]);
? }
? $e = microtime(true);
? echo "For循環环:".($e-$t)."n";
?>

?

转下載:?http://www.php1.cn /Content/XiangJie_-_ShiYong_pthreadsPHP_KuoZhan_PHP_ZhenZhengDuoXianChengDeShiYong.html

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。