使用 Swoole 加速 Lumen 框架

kimistar發表於2019-01-21

前言

眾所周知,Web應用中,每次HTTP請求都需要經過PHP-FPM,由它來處理PHP指令碼。這一點在很大程度上降低了QPS,如果使用Swoole擴充套件開啟一個HTTP服務來代替PHP-FPM(同時一般情況下使用Nginx作為反向代理伺服器),則即可解決這一問題。

安裝

composer require kimistar/lumen_swoole

配置

在bootstrap/app.php中註冊service provider

$app->register(Star\LumenSwoole\SwooleServiceProvider::class);

自定義配置檔案swoole.php 覆蓋預設配置

return [
   'host' => '127.0.0.1',
    'port' => 8080,
    'daemonize' => 0,
    'dispatch_mode' => 3,
    'worker_num' => 4,
    'max_request' => 5000,
    'log_file' => storage_path('logs/swoole.log'),
    'log_level' => 5,
    'pid_file' => storage_path('logs/swoole.pid'),
    'open_tcp_nodelay' => 1,
    'heart_beat_internal' => 300,
];

同時在bootstrap/app.php載入此檔案

$app->configure('swoole');

使用

php artisan sumen start | restart | stop | reload | status

預設監聽127.0.0.1 8080埠,開啟4個worker程式

注意無法reload的檔案 @https://wiki.swoole.com/wiki/page/p-server...

包括但不限於

  • bootstrap/app.php
  • app/Providers/*
  • config/*
  • app/Console/*

注意

由於Swoole常駐記憶體的特性,Lumen中Mysql、Redis的連線需要做心跳檢測,每隔一段時間ping一次。做法如下:

// bootstrap/app.php
$app->singleton('heartBeat', function() {
    // 在此寫心跳檢測的程式碼
});

配置Nginx

server {
    listen 80;
    server_name your.domain.com;

    location / {
        try_files /_not_exists @swoole;
    }

    location @swoole {
        proxy_http_version 1.1;
        #proxy_set_header Connection "keep-alive";
        proxy_set_header Host $host;
        proxy_set_header SERVER_PORT $server_port;
        proxy_set_header REMOTE_ADDR $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Real-IP $remote_addr;
        # proxy_set_header HTTPS "on";

        proxy_pass http://127.0.0.1:8080;
    }
}

ab測試

ab -c 100 -n 20000  http://api.swoole.cn/
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking api.swoole.cn (be patient)
Completed 2000 requests
Completed 4000 requests
Completed 6000 requests
Completed 8000 requests
Completed 10000 requests
Completed 12000 requests
Completed 14000 requests
Completed 16000 requests
Completed 18000 requests
Completed 20000 requests
Finished 20000 requests

Server Software:        nginx/1.10.2
Server Hostname:        api.swoole.cn
Server Port:            80

Document Path:          /
Document Length:        9 bytes

Concurrency Level:      100
Time taken for tests:   2.373 seconds
Complete requests:      20000
Failed requests:        0
Write errors:           0
Total transferred:      6240000 bytes
HTML transferred:       180000 bytes
Requests per second:    8427.15 [#/sec] (mean)
Time per request:       11.866 [ms] (mean)
Time per request:       0.119 [ms] (mean, across all concurrent requests)
Transfer rate:          2567.65 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   1.1      1       7
Processing:     1   11   5.2     10      40
Waiting:        1   10   5.1      9      40
Total:          1   12   5.2     11      41

Percentage of the requests served within a certain time (ms)
  50%     11
  66%     13
  75%     15
  80%     16
  90%     19
  95%     22
  98%     25
  99%     28
 100%     41 (longest request)

Git地址:https://github.com/kimistar/lumen_swoole

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章