Score:0

เซิร์ฟเวอร์ทำงานช้า [nginx + php+fpm + mariadb]

ธง co
Rob

ฉันมีปัญหาในการค้นหาคอขวดของประสิทธิภาพเซิร์ฟเวอร์ที่ช้าของฉัน ไซต์ wordpress เดียว (ผู้ใช้ออนไลน์ 10-40 ราย) พร้อมการแคช fastcgi และการแคช HTML cloudflare เต็มรูปแบบ ประสิทธิภาพของไซต์นั้นดีสำหรับผู้เยี่ยมชมเนื่องจากการแคช ผู้ใช้ที่เข้าสู่ระบบต้องเผชิญกับเวลาในการโหลดหน้าเว็บ 1-10 วินาที การตรวจสอบแบบสอบถามใช้สำหรับการดีบัก ไซต์ทำงานได้ดีขึ้นบนเครื่อง 1 คอร์ แรม 2GB ไม่รู้ว่าอะไรเป็นสาเหตุของสิ่งนี้ ความช่วยเหลือใด ๆ ที่ชื่นชมมาก ขอขอบคุณ.

ตัวอย่างของการโหลดโพสต์เดียวที่ช้า:ตรวจสอบแบบสอบถามโหลดช้า

ตัวอย่างการโหลดโพสต์เดียวที่ดี: ตรวจสอบแบบสอบถามโหลดเร็ว

ฉันใช้ KVM 2 Cores @ 3.50+ GHz หน่วยความจำ 8 GB 160 GB SSD
    รุ่น nginx: nginx/1.14.1
    PHP 7.4.22 (cli) + memcached 
    10.6.3-MariaDB

root@localhost:~# ฟรี -m
              รวมใช้บัฟ/แคชที่ใช้ร่วมกันฟรี
เมม: 7987 1546 195 121 6245 6020
สลับ: 8191 268 7923

การตั้งค่า PHP-FPM: (พยายามเพิ่มแล้ว ไม่มีการเปลี่ยนแปลง)

pm = ไดนามิก
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 GB)
key_buffer_size 134217728 (~128 MB)
max_allowed_packet 16777216 (~16 MB)
max_connections 151
query_cache_limit 1048576 (ประมาณ 1 MB)
query_cache_size 67108864 (~64 MB)
query_cache_type เปิดอยู่

nginx.conf

ผู้ใช้ www-data;
worker_processes อัตโนมัติ
pid /run/nginx.pid;
รวม /etc/nginx/modules-enabled/*.conf;

เหตุการณ์ {
    worker_connections 2048;
    # multi_accept บน;
}

http {

    ##
    # การตั้งค่าพื้นฐาน
    ##

    ส่งไฟล์บน;
    tcp_nopush บน;
    tcp_nodelay บน;
    types_hash_max_size 2048;
    # ปิด server_tokens;
    เปิด proxy_buffering;
    access_log off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect ปิด;

    รวม /etc/nginx/mime.types;
    แอปพลิเคชัน default_type/octet-stream;

    ##
    # การตั้งค่า SSL
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # วาง SSLv3 อ้างอิง: พุดเดิ้ล
    เปิด ssl_prefer_server_ciphers;

    ##
    # การตั้งค่าการบันทึก
    ##

    # access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # การตั้งค่า Gzip
    ##

    เปิด gzip;
    gzip_disable "msie6";

    # gzip_vary บน;
    # gzip_proxyed ใด ๆ ;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types ข้อความ/ข้อความล้วน/แอปพลิเคชัน css/แอปพลิเคชัน json/ข้อความจาวาสคริปต์/แอปพลิเคชัน xml/แอปพลิเคชัน xml/xml+rss ข้อความ/จาวาสคริปต์;

    ##
    # การกำหนดค่าโฮสต์เสมือน
    ##
    
    ################## แคช ###############
    proxy_cache_path /etc/nginx/static-cache levels=1:2 keys_zone=s3_cache:200m max_size=1800G inactive=10y use_temp_path=off;

    fastcgi_cache_path /etc/nginx/fastcgi-cache levels=1:2 keys_zone=phpcache:50m max_size=1g inactive=7d use_temp_path=off;
    fastcgi_cache_key "$scheme$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 ยูนิกซ์:/var/run/php/php7.4-fpm.sock;
        fastcgi_index index.php;
            fastcgi_read_timeout 150;
        fastcgi_buffers 16 16k; 
        fastcgi_buffer_size 32k;
        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 60m;
ข้อผิดพลาด fastcgi_cache_use_stale หมดเวลาอัปเดต invalid_header http_500 http_503;
fastcgi_cache_min_uses 1;
fastcgi_cache_lock บน;
add_header X-FastCGI-แคช $upstream_cache_status;

}

แก้ไข: ฉันทำการทดสอบนอก Wordpress สร้างสตริงสุ่ม 100,000 รายการสำหรับรอบ

    <?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 flag
เปิดใช้[บันทึกข้อความค้นหาช้า](https://mariadb.com/kb/en/slow-query-log/) (โดยใช้เวลา long_query_time ที่สมเหตุสมผลกว่า เช่น 1 วินาที) จากนั้นตรวจสอบในภายหลังเพื่อดูว่ามีอะไรน่าสนใจหรือไม่ ถูกบันทึก
Rob avatar
co flag
Rob
ฉันทำ. นี่คือข้อความค้นหาช้าที่บันทึกไว้ล่าสุด: https://pastebin.com/spyvBGSR แก้ไข: นี่คือบันทึกช้าของ PHP Mysql ดูเหมือนจะไม่มีปัญหา
cn flag
หากคุณได้รับ `memcached-class-object-cache.php` ที่อ้างอิงด้านบนของบันทึกช้าของ PHP-FPM เป็นประจำ แสดงว่ามีปัญหากับอินสแตนซ์/เซิร์ฟเวอร์ Memcached ทำไมไม่ Redis แทน?
Rob avatar
co flag
Rob
แทนที่ Memcached ด้วย Redis ไม่มีการปรับปรุง
Rob avatar
co flag
Rob
นี่คือภาพหน้าจอจากโปรไฟล์ xdebug: https://prnt.sc/1tuike7 ฉันไม่มีประสบการณ์เกี่ยวกับเรื่องนี้ ดังนั้นนี่จึงไม่ตอบคำถามใดๆ ให้ฉัน
ua flag
กำจัดแคช คุณไม่มีระบบที่ยุ่งมากพอที่จะใช้มันอย่างคุ้มค่า
Rob avatar
co flag
Rob
เหตุใดฉันจึงต้องการกำจัดการแคชและให้บริการคำขอที่ช้าสำหรับผู้ใช้ของฉัน
Score:0
ธง co
Rob

ดูเหมือนว่าปัญหาจะได้รับการแก้ไข ติดต่อผู้ให้บริการ VPS ของฉัน พวกเขายืนยันว่าเซิร์ฟเวอร์ของฉันมีการควบคุมความร้อนและพวกเขาจะแก้ปัญหานี้ได้ นี่เป็นคำตอบว่าทำไมบางคำขอจึงช้า

โพสต์คำตอบ

คนส่วนใหญ่ไม่เข้าใจว่าการถามคำถามมากมายจะปลดล็อกการเรียนรู้และปรับปรุงความสัมพันธ์ระหว่างบุคคล ตัวอย่างเช่น ในการศึกษาของ Alison แม้ว่าผู้คนจะจำได้อย่างแม่นยำว่ามีคำถามกี่ข้อที่ถูกถามในการสนทนา แต่พวกเขาไม่เข้าใจความเชื่อมโยงระหว่างคำถามและความชอบ จากการศึกษาทั้ง 4 เรื่องที่ผู้เข้าร่วมมีส่วนร่วมในการสนทนาด้วยตนเองหรืออ่านบันทึกการสนทนาของผู้อื่น ผู้คนมักไม่ตระหนักว่าการถามคำถามจะมีอิทธิพลหรือมีอิทธิพลต่อระดับมิตรภาพระหว่างผู้สนทนา