Home > Backend Development > PHP Tutorial > Use of PHP multi-threading_PHP tutorial

Use of PHP multi-threading_PHP tutorial

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2016-07-13 10:36:22
Original
786 people have browsed it



The performance bottleneck of most websites is not on the PHP server, because it can be easily dealt with by simply increasing the number of servers or CPU cores horizontally (for various cloud hosts, it is more convenient to increase the number of VPS or CPU cores, and increase it directly with a backup image VPS, even the operating system and environment do not need to be installed and configured), but lie in the MySQL database. If you use a MySQL database and a joint query SQL, you may be able to handle the business logic. However, if you encounter a large number of concurrent requests, you will stop working. If you use a NoSQL database, it may take ten queries to process the same business logic, but each query is faster than MySQL. Ten loop NoSQL queries may be faster than a MySQL joint query, which can handle tens of thousands of times/second. The query is totally fine. If you add PHP multi-threading, query NoSQL through ten threads at the same time, and return the result summary output, the speed will be faster. In our actual APP product, we call a PHP interface that recommends products in real time based on user preferences. PHP needs to initiate 500 to 1,000 queries to the BigSea NoSQL database to calculate the user's personalized preference product data in real time. The role of PHP multi-threading is very obvious.

PHP extension download: https://github.com/krakjoe/pthreads
PHP manual document: http://php.net/manual/zh/book.pthreads.php


Implementation of PHP multi-threading


Extended compilation and installation (Linux), the editing parameter --enable-maintainer-zts is required:

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-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
Add:
extension = "pthreads.so"

Give a PHP multi-threading and For loop to capture the PHP code example of Baidu search page

  1. class test_thread_run extends Thread
  2.        public $url;                                   
  3.        public $data;                                   
  4. Public function __construct($url)
  5.                                                                       
  6.              $this->url = $url;                                   
  7.          } 
  8. Public function run()
  9.                                                                        
  10. If(($url = $this->url))
  11.                                                                  
  12.                    $this->data = model_http_curl_get($url);                                     
  13.                                                                                                            
  14.         } 
  15. function model_thread_result_get($urls_array)
  16. foreach ($urls_array as $key => $value)
  17.                                                                       
  18.           $thread_array[$key] = new test_thread_run($value["url"]);
  19. $thread_array[$key]->start();
  20.         } 
  21. foreach ($thread_array as $thread_array_key => $thread_array_value)
  22.                                                                       
  23. ​​​​​while($thread_array[$thread_array_key]->isRunning())
  24.                                                                  
  25. usleep(10);
  26.                                                                                                            
  27. If($thread_array[$thread_array_key]->join())
  28.                                                                  
  29.                $variable_data[$thread_array_key] = $thread_array[$thread_array_key]->data;
  30.                                                                                                              
  31.          } 
  32. Return $variable_data;
  33. }  
  34.   
  35.   function model_http_curl_get($url,$userAgent="")   
  36.   {  
  37.       $userAgent = $userAgent ? $userAgent : 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2)';   
  38.       $curl = curl_init();  
  39.       curl_setopt($curl, CURLOPT_URL, $url);  
  40.       curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);  
  41.       curl_setopt($curl, CURLOPT_TIMEOUT, 5);  
  42.       curl_setopt($curl, CURLOPT_USERAGENT, $userAgent);  
  43.       $result = curl_exec($curl);  
  44.       curl_close($curl);  
  45.       return $result;  
  46.   }  
  47.   
  48.   for ($i=0; $i < 100; $i++)   
  49.   {   
  50.       $urls_array[] = array("name" => "baidu", "url" => "http://www.baidu.com/s?wd=".mt_rand(10000,20000));  
  51.   }  
  52.   
  53.   $t = microtime(true);  
  54.   $result = model_thread_result_get($urls_array);  
  55.   $e = microtime(true);  
  56.   echo "多线程:".($e-$t)."n";  
  57.   
  58.   $t = microtime(true);  
  59.   foreach ($urls_array as $key => $value)   
  60.   {  
  61.       $result_new[$key] = model_http_curl_get($value["url"]);  
  62.   }  
  63.   $e = microtime(true);  
  64.   echo "For循环:".($e-$t)."n";  
  65. ?>  

原文:http://blog.s135.com/pthreads/  张宴

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/739145.htmlTechArticle大多数网站的性能瓶颈不在PHP服务器上,因为它可以简单地通过横向增加服务器或CPU核数来轻松应对(对于各种云主机,增加VPS或CPU核数就...
Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template