ホームページ  >  記事  >  バックエンド開発  >  pthreads を使用して実際の PHP マルチスレッドを実装する (PHP5.3 以降が必要)_PHP チュートリアル

pthreads を使用して実際の PHP マルチスレッドを実装する (PHP5.3 以降が必要)_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 10:30:31740ブラウズ

前回の記事で、ほとんどの Web サイトのパフォーマンスのボトルネックは PHP サーバーにあるわけではないと言いました。サーバーまたは CPU コアの数を水平方向に増やすだけで簡単に対処できます (さまざまなクラウド ホストの場合、VPS の数を増やす)。バックアップ イメージを使用して VPS を直接追加することもでき、さらに便利です。オペレーティング システムや環境をインストールして構成する必要さえありません。代わりに、MySQL データベースに依存します。

MySQL データベースと結合クエリ SQL を使用する場合は、ビジネス ロジックを処理できる可能性がありますが、大量の同時リクエストが発生すると、動作が停止します。

NoSQL データベースを使用する場合、同じビジネス ロジックを処理するのに 10 個のクエリが必要になる可能性がありますが、各クエリは MySQL よりも高速です。10 ループの NoSQL クエリは、数万回処理できる 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=/ データ/apps/mysql/bin/mysql_config --with-iconv-dir --with-freetype-dir=/データ/apps/libs --with-jpeg-dir=/データ/apps/libs -- with-png- dir=/Data/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

php.iniを追加します:

コードをコピーします コードは次のとおりです:

vi /Data/apps/php/etc/php.ini
extension = "pthreads.so"

Baidu 検索ページの PHP コード例をキャプチャするための PHP マルチスレッドと For ループを提供します:

コードをコピーします コードは次のとおりです:

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

public function __construct($url)
{
$this->url = $url;
}

公開function 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] = new 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;
}
}
return $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)."
";

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

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/765166.html技術記事私の前の文章によると、ほとんどのネットワーク サイトのパフォーマンス ボトルは PHP サーバー上に存在しないため、横方向の追加サーバーまたは CPU コア数を介して轻松应对(さまざまなクラウド ホストに対して...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。