Назад | Перейти на главную страницу

nginx + php-fpm работает очень медленно

У меня очень низкий уровень VPS - 1 ГБ оперативной памяти и 1 процессор с 30 ГБ SSD под управлением CentOS (v7.2.1511). На сервере только серверы php-fpm (v5.4.16) и nginx (1.6.3). Базы данных Mysql и Mongo находятся на другом сервере.

Я знаю, что у моих серверов очень низкие характеристики, но производительность, которую я получаю менее чем за 1 запрос в секунду, безумно медленная - для запуска сценария PHP требуется около 20 секунд. Статический контент работает очень быстро. Это динамический контент, который длится вечно.

Вот мои файлы конфигурации:

# php-fpm.d/www.conf:

listen = /var/run/php-fpm/php-fpm.sock
pm = dynamic
pm.start_servers = 3
pm.min_spare_servers = 2
pm.max_spare_servers = 5
pm.max_children = 5
php_value[session.session_handler] = files

# nginx.conf

worker_processes = 1
events {
    worker_connections = 512;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                  '$status $body_bytes_sent "$http_referer" '
                  '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;


    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    include /etc/nginx/sites/*;
}

# a config for a website

server {
    listen 80;
    server_name example.com;
    index index.php;
    root /var/www/example.com;
    include conf.d/wordpress.conf;
}


# conf.d/wordpress.conf

location / {
    try_files $uri $uri/ /index.php?$args;
}

include conf.d/php.conf;

# conf.d/php.conf

location ~ \.php$ {
    fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
    fastcgi_index index.php;
    include fastcgi_params;
}

# fastcgi_params
fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  HTTPS              $https if_not_empty;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;

fastcgi_param  REDIRECT_STATUS    200;
fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;

Я считаю, что есть проблема с php-fpm, поэтому я все еще настраиваю ее. Вы можете помочь мне разобраться в проблеме?

Большинство медленных страниц php можно связать с проблемами базы данных. Возможно, вы захотите создать сценарий, который выполняет только 1 запрос, и вывести время, необходимое для выполнения запроса. Посмотри пожалуйста https://stackoverflow.com/questions/17035859/how-to-find-php-execution-time для способов записи времени выполнения. Записывайте время выполнения по частям в своем скрипте, оттуда мы будем определять, являются ли запросы или другие вещи в PHP виноватыми или проблема в конфигурации. Если время выполнения, записанное в PHP (например, от начала до конца скрипта), значительно больше, чем время, которое испытывает браузер (проверьте время запроса, используя, например, инструменты разработчика Chrome), то у вас могут быть проблемы с настройкой. Если это то же самое, то у нас может быть проблема с производительностью, где мы можем проанализировать по времени запуска и остановки различных частей скрипта.