Рейтинг:0

Низкая производительность сервера [nginx + php+fpm + mariadb]

флаг co
Rob

У меня проблемы с поиском узких мест в моей низкой производительности сервера. Один сайт WordPress (10-40 онлайн-пользователей) с кэшированием fastcgi и полным кэшированием HTML cloudflare. Производительность сайта в порядке для посетителей из-за кэширования, вошедшие пользователи сталкиваются со временем загрузки страницы 1-10 с. Монитор запросов используется для отладки. Сайт работал лучше на 1-ядерном компьютере с 2-гигабайтной оперативной памятью. Не знаю, что вызывает это. Буду признателен за любую оказанную помощь. Спасибо.

Пример медленной загрузки одного поста:Медленная загрузка монитора запросов

Пример хорошей загрузки одной почты: Быстрая загрузка монитора запросов

Я использую KVM 2 ядра @ 3,50+ ГГц, 8 ГБ памяти, 160 ГБ SSD.
    Версия nginx: nginx/1.14.1
    PHP 7.4.22 (cli) + memcached 
    10.6.3-МарияБД

root@localhost:~# бесплатно -m
              общее количество использованных бесплатных общих баффов/доступных кешей
Память: 7987 1546 195 121 6245 6020
Обмен: 8191 268 7923

Настройки PHP-FPM: (Пытался увеличить, без изменений)

вечера = динамический
pm.max_children = 100
pm.start_servers = 8
pm.min_spare_servers = 4
pm.max_spare_servers = 8
pm.max_requests = 200

База данных

Версия сервера 5.5.5
Расширение mysqli
Версия клиента 70422 (7.4.22)
innodb_buffer_pool_size 2147483648 (~ 2 ГБ)
key_buffer_size 134217728 (~128 МБ)
max_allowed_packet 16777216 (~16 МБ)
max_connections 151
query_cache_limit 1048576 (~ 1 МБ)
query_cache_size 67108864 (~ 64 МБ)
query_cache_type ВКЛ.

nginx.conf

www-данные пользователя;
рабочие_процессы авто;
pid /run/nginx.pid;
включить /etc/nginx/modules-enabled/*.conf;

События {
    worker_connections 2048;
    # multi_accept on;
}

http {

    ##
    # Основные настройки
    ##

    отправить файл включен;
    tcp_nopush включен;
    tcp_nodelay включен;
    типы_хэш_макс_размер 2048;
    # server_tokens off;
    прокси_буферизация включена;
    доступ_лог выключен;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

    включить /etc/nginx/mime.types;
    default_type application/octet-stream;

    ##
    # Настройки SSL
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Удаление SSLv3, ссылка: POODLE
    ssl_prefer_server_ciphers включен;

    ##
    # Настройки ведения журнала
    ##

    # access_log /var/log/nginx/access.log;
    журнал_ошибок /var/log/nginx/error.log;

    ##
    # Настройки Gzip
    ##

    gzip включен;
    gzip_disable "msie6";

    # gzip_vary on;
    # gzip_proxyed любой;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Конфигурации виртуального хоста
    ##
    
    ################## кэши ################
    proxy_cache_path /etc/nginx/static-cache level=1:2 keys_zone=s3_cache:200m max_size=1800G inactive=10y use_temp_path=off;

    fastcgi_cache_path /etc/nginx/fastcgi-cache level=1:2 keys_zone=phpcache:50m max_size=1g inactive=7d use_temp_path=off;
    fastcgi_cache_key "$схема$request_method$host$request_uri";

    ##############################
    client_max_body_size 2000M;



    включить /etc/nginx/conf.d/*.conf;
    включить /etc/nginx/sites-enabled/*;
}

конфиг сервера nginx

# передать скрипты PHP на сервер FastCGI
расположение ~ \.php$ {
        try_files $uri =404;
       fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
        fastcgi_index index.php;
            fastcgi_read_timeout 150;
        fastcgi_buffers 16 16k; 
        fastcgi_buffer_size 32 КБ;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        включить fastcgi_params;

fastcgi_cache_bypass $skip_cache;
fastcgi_no_cache $skip_cache;
fastcgi_cache phpcache;
fastcgi_cache_valid 200 301 302 60 м;
fastcgi_cache_use_stale ошибка тайм-аута обновления invalid_header http_500 http_503;
fastcgi_cache_min_uses 1;
fastcgi_cache_lock включен;
add_header X-FastCGI-Cache $upstream_cache_status;

}

РЕДАКТИРОВАТЬ: Я провел некоторое тестирование вне Wordpress. Генерация 100000 случайных строк за цикл.

    <?php $start_time = microtime(true); ?>

<?php        ini_set('display_errors', 1);
        ini_set('display_startup_errors', 1);
        error_reporting(E_ALL);
        
    # define("WP_USE_THEMES", false);
    #require_once("/var/www/server/wp-blog-header.php");


        for($i = 0; $i < 100000; $i++){
            generateRandomString(2);
        }


function generateRandomString($length = 10) {
    $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $charactersLength = strlen($characters);
    $randomString = '';
    for ($i = 0; $i < $length; $i++) {
        $randomString .= $characters[rand(0, $charactersLength - 1)];
    }
    return $randomString;
}

        ?>

This page was generated in <?php echo(number_format(microtime(true) - $start_time, 2)); ?>

И результаты очень те же. Некоторые запросы завершаются за 0,1 секунды, некоторые занимают до 5 секунд. Похоже, PHP отлично справляется со своей работой. Может быть, это php-fpm замедляет работу, а затем подключается к nginx?

Michael Hampton avatar
флаг cz
Включите [журнал медленных запросов](https://mariadb.com/kb/en/slow-query-log/) (с более разумным значением long_query_time, скажем, 1 с), а затем проверьте его позже, чтобы узнать, есть ли что-нибудь интересное. был зарегистрирован.
Rob avatar
флаг co
Rob
Я сделал. Вот последний записанный медленный запрос: https://pastebin.com/spyvBGSR EDIT: это медленный журнал PHP. Mysql не кажется проблемой.
флаг cn
Если вы регулярно получаете ссылку на `memcached-class-object-cache.php` поверх медленного журнала PHP-FPM, это указывает на проблему с экземпляром/сервером Memcached. Почему бы не Redis вместо этого?
Rob avatar
флаг co
Rob
Заменил Memcached на Redis. Никаких улучшений.
Rob avatar
флаг co
Rob
Вот скриншот из профиля xdebug: https://prnt.sc/1tuike7 У меня нет опыта работы с этим, поэтому это не отвечает мне ни на один вопрос.
флаг ua
Избавьтесь от кеширования. У вас недостаточно загруженная система, чтобы ею можно было пользоваться.
Rob avatar
флаг co
Rob
Зачем мне избавляться от кеширования и обслуживать медленные запросы для своих пользователей?
Рейтинг:0
флаг co
Rob

Похоже, проблема решена. Связался с моим провайдером VPS, они подтвердили, что мой сервер термальный, и они решат эту проблему. Это объясняет, почему некоторые запросы выполняются медленно.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.