佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 詳解PHP7開啟OPcache和Swoole性能的提升對比

詳解PHP7開啟OPcache和Swoole性能的提升對比

熱門標(biāo)簽:Linux服務(wù)器 電子圍欄 科大訊飛語音識別系統(tǒng) 阿里云 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 服務(wù)器配置 團(tuán)購網(wǎng)站

前期準(zhǔn)備

測試所用的主機(jī)為虛擬機(jī),虛擬機(jī)配置在雙核4GB的個(gè)人電腦中。虛擬機(jī)系統(tǒng)為linux,http服務(wù)器采用nginx,用lnmp腳本安裝nginx、mysql、php。Laravel框架為7.X版本。

配置站點(diǎn),在nginx的server塊中配置虛擬主機(jī)

server{ listen 80; root "/vagrant/www/laravel7/public"; server_name test.laravel.com; index index.html index.php; location / { try_files $uri $uri/ /index.php?$args; } location ~ \.php$ { fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_index index.php; fastcgi_split_path_info ^(.+\.php)(.*)$; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }

編輯/etc/hosts文件,在新行添加127.0.0.1 test.laravel.com

打開項(xiàng)目,新建控制器TestController,在里面新建一個(gè)test方法:

?php
namespace App\Http\Controllers;
 
 
 
class TestController extends Controller
{
    public function test()
    {
    	return 123;
    }
 
    
}

在routes/api.php中注冊一個(gè)路由:

Route::get('test', 'TestController@test');

在app/Http/Kernel文件中,關(guān)掉頻率限制中間件throttle。

不開啟opcache和laravel

修改php-fpm.conf文件,修改pm和pm.max_children 配置,pm設(shè)置為static,pm.max_children設(shè)置為50,以獲得較好的并發(fā)性能。

[www] listen = /tmp/php-cgi.sock listen.backlog = -1 listen.allowed_clients = 127.0.0.1 listen.owner = www listen.group = www listen.mode = 0666 user = www group = www pm = static pm.max_children = 50 pm.start_servers = 10 pm.min_spare_servers = 10 pm.max_spare_servers = 20 request_terminate_timeout = 100 request_slowlog_timeout = 0 slowlog = var/log/slow.log

重啟fpm后用ab壓測:ab -n 1000 -c 100 http://test.laravel.com/api/test

Server Software:        nginx

Server Hostname:        test.laravel.com

Server Port:            80

Document Path:          /api/test

Document Length:        3 bytes

Concurrency Level:      100

Time taken for tests:   148.306 seconds

Complete requests:      1000

Failed requests:        0

Total transferred:      253000 bytes

HTML transferred:       3000 bytes

Requests per second:    6.74 [#/sec] (mean)

Time per request:       14830.553 [ms] (mean)

Time per request:       148.306 [ms] (mean, across all concurrent requests)

Transfer rate:          1.67 [Kbytes/sec] received

此時(shí)的并發(fā)大約為為 7 qps

開啟OPcache

在配置文件php.ini文件中開啟opcache

zend_extension="opcache.so" opcache.enable=1 opcache.memory_consumption=128 opcache.max_accelerated_files=10000 opcache.revalidate_freq=60 opcache.fast_shutdown=1 opcache.enable_cli=1 opcache.interned_strings_buffer=8

重啟fpm后,用ab壓測:ab -n 1000 -c 100 http://test.laravel.com/api/test

Server Software:        nginx

Server Hostname:        test.laravel.com

Server Port:            80

Document Path:          /api/test

Document Length:        4 bytes

Concurrency Level:      100

Time taken for tests:   11.006 seconds

Complete requests:      1000

Failed requests:        0

Total transferred:      254000 bytes

HTML transferred:       4000 bytes

Requests per second:    90.86 [#/sec] (mean)

Time per request:       1100.590 [ms] (mean)

Time per request:       11.006 [ms] (mean, across all concurrent requests)

Transfer rate:          22.54 [Kbytes/sec] received

Connection Times (ms)

              min  mean[+/-sd] median   max

Connect:        0    1   4.3      0      16

Processing:   409 1069 152.0   1092    1414

Waiting:      408 1069 152.0   1092    1414

Total:        424 1070 149.6   1092    1414

Percentage of the requests served within a certain time (ms)

  50%   1092

  66%   1126

  75%   1149

  80%   1162

  90%   1203

  95%   1242

  98%   1280

  99%   1309

 100%   1414 (longest request)

此時(shí)的達(dá)到了 90qps,性能是未開啟時(shí)的 10 倍以上!。

使用swoole加速包

開源的laravel-swoole加速包

在項(xiàng)目目錄下運(yùn)行composer命令安裝;在nginx的配置文件中配置,將請求轉(zhuǎn)發(fā)到swoole監(jiān)聽的端口。

用 ab 壓測 : ab -n 1000 -c 100 http://test.laravel.com/api/test

Server Software:        nginx

Server Hostname:        test.laravel.com

Server Port:            80

Document Path:          /api/test

Document Length:        4 bytes

Concurrency Level:      100

Time taken for tests:   1.158 seconds

Complete requests:      1000

Failed requests:        0

Total transferred:      225000 bytes

HTML transferred:       4000 bytes

Requests per second:    863.46 [#/sec] (mean)

Time per request:       115.813 [ms] (mean)

Time per request:       1.158 [ms] (mean, across all concurrent requests)

Transfer rate:          189.72 [Kbytes/sec] received

速度起飛!達(dá)到了800qps!

也就是一百多倍?

總結(jié)

當(dāng)然這只是一個(gè)比較簡單的測試,但是總的來說opcache擴(kuò)展和swoole擴(kuò)展對php腳本性能的提升還是很明顯的。

以上就是詳解PHP7開啟OPcache和Swoole性能的提升對比的詳細(xì)內(nèi)容,更多關(guān)于PHP7開啟OPcache和Swoole性能的提升對比的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • 如何使用OPCache提升PHP的性能
  • 解決PHP Opcache 緩存刷新、代碼重載出現(xiàn)無法更新代碼的問題
  • PHP如何開啟Opcache功能提升程序處理效率
  • php加速緩存器opcache,apc,xcache,eAccelerator原理與配置方法實(shí)例分析
  • 啟用OPCache提高PHP程序性能的方法
  • PHP解決高并發(fā)問題(opcache)

標(biāo)簽:蚌埠 棗莊 萍鄉(xiāng) 大理 廣元 衢州 江蘇 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解PHP7開啟OPcache和Swoole性能的提升對比》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    泗阳县| 吉首市| 翁牛特旗| 临猗县| 延寿县| 大宁县| 丹巴县| 靖江市| 永宁县| 巩义市| 霍林郭勒市| 观塘区| 海阳市| 三穗县| 鄂托克前旗| 漾濞| 金寨县| 梁平县| 台中县| 龙陵县| 武定县| 报价| 洛川县| 柳河县| 虎林市| 麦盖提县| 铁力市| 兰州市| 雅江县| 郯城县| 中西区| 永平县| 菏泽市| 伊金霍洛旗| 芮城县| 望城县| 阜康市| 舒兰市| 肥东县| 新余市| 会昌县|