前の記事で、ほとんどの Web サイトのパフォーマンスのボトルネックは PHP サーバーにあるわけではないと言いました。サーバーまたは CPU コアの数を水平方向に (さまざまな用途に合わせて) 増やすだけで簡単に対処できるからです。クラウド ホストでは、VPS または CPU コアの数を増やす方が便利です。バックアップ イメージを使用して VPS を直接追加できます。ただし、MySQL データベースはインストールして構成する必要もありません。
MySQL データベースと結合クエリ SQL を使用する場合は、ビジネス ロジックを処理できる可能性がありますが、大量の同時リクエストが発生すると、動作が停止します。
NoSQL データベースを使用する場合、同じビジネス ロジックを処理するのに 10 個のクエリが必要になる可能性がありますが、各クエリは MySQL よりも高速です。NoSQL クエリの 10 ループは、1 つの MySQL 結合クエリよりも高速である可能性があります。 1 秒あたりのクエリ数はまったく問題ありません。
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=/Data/apps/libs --with-jpeg-dir=/Data/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-ztsmake cleanmakemake install unzip pthreads-master.zipcd pthreads-master/Data/apps/php/bin/phpize./configure --with-php-config=/Data/apps/php/bin/php-configmakemake install
php.ini に追加します:
vi /Data/apps/php/etc/php.iniextension = "pthreads.so"
Baidu 検索ページの PHP コード例をキャプチャするための PHP マルチスレッドと For ループを提供します:
<?php class test_thread_run extends Thread { public $url; public $data; public function __construct($url) { $this->url = $url; } public 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 (compatible; 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 < 100; $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 "For循环:".($e-$t)."";?>