เพิ่มประสิทธิภาพ Apache สำหรับ 10K + wordpress ดูต่อวันบน 2GB RAM E6500 CPU


10

ฉันมีเซิร์ฟเวอร์เฉพาะที่มี apache / php บน ubuntu ที่ให้บริการบล็อก Wordpress ของฉันด้วยจำนวนหน้าที่มีการเปิดประมาณ 10K + ต่อวัน ฉันมี W3TC plug-in ติดตั้งไว้กับ APC

แต่ทุกขณะนี้จากนั้นเซิร์ฟเวอร์หยุดตอบสนองหรือตายช้าและฉันต้องรีสตาร์ท apache เพื่อรับมันกลับมา

นี่คือการกำหนดค่าของฉันฉันทำอะไรผิด

ServerRoot "/etc/apache2"
LockFile /var/lock/apache2/accept.lock
PidFile ${APACHE_PID_FILE}
TimeOut 40
KeepAlive on
MaxKeepAliveRequests 200
KeepAliveTimeout 2
<IfModule mpm_prefork_module>
  StartServers 5
  MinSpareServers 5
  MaxSpareServers 8
  ServerLimit        80
  MaxClients         80
  MaxRequestsPerChild 1000
</IfModule>
<IfModule mpm_worker_module>
  StartServers       3
  MinSpareServers    3
  MaxSpareServers    3
  ServerLimit        80
  MaxClients         80
  MaxRequestsPerChild  1000
</IfModule>
<IfModule mpm_event_module>
  StartServers       3
  MinSpareServers    3
  MaxSpareServers    3
  ServerLimit        80
  MaxClients         80
  MaxRequestsPerChild  1000
</IfModule>
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}
AccessFileName .htaccess
<Files ~ "^\.ht">
  Order allow,deny
  Deny from all
  Satisfy all
</Files>
DefaultType text/plain
HostnameLookups Off
ErrorLog /var/log/apache2/error.log
LogLevel error
Include /etc/apache2/mods-enabled/*.load
Include /etc/apache2/mods-enabled/*.conf
Include /etc/apache2/httpd.conf
Include /etc/apache2/ports.conf
LogFormat "%v:%p %h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" vhost_combined
LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %O" common
LogFormat "%{Referer}i -> %U" referer
LogFormat "%{User-agent}i" agent
CustomLog /var/log/apache2/other_vhosts_access.log vhost_combined
Include /etc/apache2/conf.d/
Include /etc/apache2/sites-enabled/

คำตอบ:


23

ประสิทธิภาพ WordPress ของฉันและแคชสแต็ค

นี่เป็นสแต็กประสิทธิภาพ WordPress ที่ยอดเยี่ยมสำหรับเซิร์ฟเวอร์เดี่ยวหรือ VPS ระดับต่ำถึงระดับกลาง ฉันจัดประเภทช่วงกลางเป็นแกนเดียวที่มีหน่วยความจำประมาณ 1G และไดรฟ์ที่รวดเร็วพอสมควร

ในกล่องของคุณจะสามารถแสดงผลการดูหน้าเว็บมากกว่า 10K ต่อชั่วโมง

เซิร์ฟเวอร์สแต็ก

  • Linux - Debian Lenny หรือ Ubuntu
  • Nginx - กำหนดค่าเป็นแคชไฟล์สแตติกพร็อกซีย้อนกลับ
  • Apache - Apache จะจัดการ PHP ที่ถูกโหลดโดย Nginx บนพอร์ตอื่น
  • MySql - ต้องการโดย WP ตรวจสอบให้แน่ใจว่าคุณใช้เวอร์ชันที่เสถียรล่าสุด
  • PHP - เวอร์ชันเสถียรล่าสุดของ 5.2 หรือ 5.3 สาขา

PHP Cache

  • APC - กำหนดค่าด้วยหน่วยความจำ mmap และขนาด shm อย่างน้อย 128M

WordPress ปลั๊กอินประสิทธิภาพสแต็ค

  • ตัวรวมแคชพร็อกซี Nginx
  • W3 รวม Cache - ชุดแคชหน้าไปยังดิสก์เพิ่มลดขนาดไปยังดิสก์และวัตถุและฐานข้อมูลเพื่อ APC
  • Self Hosted CDN - สร้างนามแฝง 4 ชื่อที่ชี้ไปที่โดเมนบนเซิร์ฟเวอร์ตั้งค่าเพียงเพื่อให้บริการไฟล์คงที่

ด้วย W3 Total Cache เรากำลังใช้ดิสก์สำหรับแคชของหน้าเว็บและย่อขนาดเนื่องจาก Nginx จะให้บริการไฟล์คงที่ของเราอย่างรวดเร็ว

วิธีกำหนดค่า Nginx เพื่อให้บริการไฟล์คงที่และส่งต่อ PHP ไปยัง Apache

ปัญหาของการใช้ Apache เพียงอย่างเดียวคือมันเปิดการเชื่อมต่อและพบ php ในทุก ๆ การร้องขอแม้กระทั่งสำหรับไฟล์สแตติก สิ่งนี้เป็นการสูญเสียการเชื่อมต่อเนื่องจาก Apache จะเปิดไว้และเมื่อคุณมีการรับส่งข้อมูลจำนวนมากการเชื่อมต่อของคุณจะชะงักเนื่องจากไม่มีการใช้งาน

โดยค่าเริ่มต้น Apache จะรับฟังคำร้องขอที่พอร์ต 80 ซึ่งเป็นเว็บพอร์ตเริ่มต้น ก่อนอื่นเราจะทำการเปลี่ยนแปลง Apache conf และไฟล์โฮสต์เสมือนของเราเพื่อฟังบนพอร์ต 8080

Apache Config

httpd.conf

ตั้ง KeepAlive เป็น off

ports.conf

NameVirtualHost *:8080
Listen 8080

ต่อโฮสต์เสมือนของไซต์

<VirtualHost 127.0.0.1:8080>
     ServerAdmin info@yoursite.com
     ServerName yoursite.com
     ServerAlias www.yoursite.com
     DocumentRoot /srv/www/yoursite.com/public_html/
     ErrorLog /srv/www/yoursite.com/logs/error.log
     CustomLog /srv/www/yoursite.com/logs/access.log combined
</VirtualHost>

คุณควรติดตั้งmod_rpafเพื่อให้บันทึกของคุณมีที่อยู่ IP จริงของผู้เยี่ยมชม หากไม่ใช่บันทึกของคุณจะมี 127.0.0.1 เป็นที่อยู่ IP ต้นทาง

กำหนดค่า Nginx

บน Debian คุณสามารถใช้ที่เก็บเพื่อติดตั้ง แต่มีเฉพาะรุ่น 0.6.33 ในการติดตั้งเวอร์ชันที่ใหม่กว่าคุณจะต้องเพิ่มแพ็คเกจแบ็กเอนนี่เลนนี่

$ nano /etc/apt/sources.list

เพิ่มบรรทัดนี้ลงในไฟล์ deb http://www.backports.org/debian lenny-backports main

$ nano /etc/apt/preferences

เพิ่มสิ่งต่อไปนี้ในไฟล์:

Package: nginx
Pin: release a=lenny-backports 
Pin-Priority: 999

ใช้คำสั่งต่อไปนี้เพื่ออิมพอร์ตคีย์จาก backports.org เพื่อตรวจสอบแพ็กเกจและอัพเดตฐานข้อมูลแพ็กเกจของระบบของคุณ:

$ wget -O - http://backports.org/debian/archive.key | apt-key add -
$ apt-get update

ตอนนี้ติดตั้งด้วย apt-get

apt-get install nginx

มันง่ายกว่าการรวบรวมจากแหล่งที่มา

Conf Nginx และไฟล์เซิร์ฟเวอร์ config

nginx.conf

user www-data;
worker_processes  4;

error_log  /var/log/nginx/error.log;
pid        /var/run/nginx.pid;

events {
    worker_connections  1024;
}

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

    access_log  /var/log/nginx/access.log;
    client_body_temp_path /var/lib/nginx/body 1 2;
    gzip_buffers 32 8k;
    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;
    tcp_nodelay        on;

    gzip  on;

  gzip_comp_level   6;
  gzip_http_version 1.0;
  gzip_min_length   0;
  gzip_types        text/html text/css image/x-icon
        application/x-javascript application/javascript text/javascript application/atom+xml application/xml ;



    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}

ตอนนี้คุณจะต้องตั้งค่าโฮสต์เสมือน Nginx ของคุณ ฉันต้องการใช้วิธีการเปิดใช้งานไซต์กับโฮสต์ v แต่ละตัวที่เชื่อมโยงกับไฟล์ในไดเรกทอรีที่มีไซต์

$ mkdir /etc/nginx/sites-available  
$ mkdir /etc/nginx/sites-enabled
$ touch /etc/nginx/sites-available/yourservername.conf
$ touch /etc/nginx/sites-available/default.conf
$ ln -s  /etc/nginx/sites-available /etc/nginx/sites-enabled
$ nano /etc/nginx/sites-enabled/default.conf

default.conf

บันทึก:

การตั้งค่าแคชแบบสแตติกในไฟล์ต่อไปนี้จะใช้ได้เฉพาะเมื่อปลั๊กอินตัวรวมแคชพร็อกซี Nginx เปิดใช้งานอยู่

proxy_cache_path  /var/lib/nginx/cache  levels=1:2   keys_zone=staticfilecache:180m  max_size=500m;
proxy_temp_path /var/lib/nginx/proxy;
proxy_connect_timeout 30;
proxy_read_timeout 120;
proxy_send_timeout 120;

#IMPORTANT - this sets the basic cache key that's used in the static file cache.
proxy_cache_key "$scheme://$host$request_uri";

upstream wordpressapache {
        #The upstream apache server. You can have many of these and weight them accordingly,
        #allowing nginx to function as a caching load balancer 
        server 127.0.0.1:8080 weight=1 fail_timeout=120s;
}

ต่อเว็บไซต์ WordPress conf (สำหรับเว็บไซต์หลายแห่งคุณจะต้องมีเพียงหนึ่ง vhost)

server {
        #Only cache 200 responses, and for a default of 20 minutes.
        proxy_cache_valid 200 20m;

        #Listen to your public IP
        listen 80;

        #Probably not needed, as the proxy will pass back the host in "proxy_set_header"
        server_name www.yoursite.com yoursite.com;
        access_log /var/log/nginx/yoursite.proxied.log;  

        # "combined" matches apache's concept of "combined". Neat.
        access_log  /var/log/apache2/nginx-access.log combined;
        # Set the real IP.
        proxy_set_header X-Real-IP  $remote_addr;

        # Set the hostname
        proxy_set_header Host $host;

        #Set the forwarded-for header.
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        location / {
                        # If logged in, don't cache.
                        if ($http_cookie ~* "comment_author_|wordpress_(?!test_cookie)|wp-postpass_" ) {
                                set $do_not_cache 1;
                        }
                        proxy_cache_key "$scheme://$host$request_uri $do_not_cache";
                        proxy_cache staticfilecache;
                        proxy_pass http://wordpressapache;
        }

        location ~* wp\-.*\.php|wp\-admin {
                        # Don't static file cache admin-looking things.
                        proxy_pass http://wordpressapache;
        }

        location ~* \.(jpg|png|gif|jpeg|css|js|mp3|wav|swf|mov|doc|pdf|xls|ppt|docx|pptx|xlsx)$ {
                        # Cache static-looking files for 120 minutes, setting a 10 day expiry time in the HTTP header,
                        # whether logged in or not (may be too heavy-handed).
                        proxy_cache_valid 200 120m;
                        expires 864000;
                        proxy_pass http://wordpressapache;
                        proxy_cache staticfilecache;
        }

        location ~* \/[^\/]+\/(feed|\.xml)\/? {
 # Cache RSS looking feeds for 45 minutes unless logged in.
                        if ($http_cookie ~* "comment_author_|wordpress_(?!test_cookie)|wp-postpass_" ) {
                                set $do_not_cache 1;
                        }
                        proxy_cache_key "$scheme://$host$request_uri $do_not_cache";
                        proxy_cache_valid 200 45m;
                        proxy_cache staticfilecache;
                        proxy_pass http://wordpressapache;
        }

        location = /50x.html {
                root   /var/www/nginx-default;
        }

        # No access to .htaccess files.
        location ~ /\.ht {
                deny  all;
        }

        }

conf CDN ที่โฮสต์ด้วยตนเอง

สำหรับ CDN ที่โฮสต์ด้วยตนเองของคุณจะต้องตั้งค่าให้บริการไฟล์คงที่โดยไม่ต้องผ่านพรอกซี

server {

        proxy_cache_valid 200 20m;
        listen 80;
        server_name yourcdndomain.com;
        access_log   /srv/www/yourcdndomain.com/logs/access.log;
        root   /srv/www/yourcdndomain.com/public_html/;

 proxy_set_header X-Real-IP  $remote_addr;

      location ~* \.(jpg|png|gif|jpeg|css|js|mp3|wav|swf|mov|doc|pdf|xls|ppt|docx|pptx|xlsx)$ {
                                # Cache static-looking files for 120 minutes, setting a 10 day expiry time in the HTTP header,
                                # whether logged in or not (may be too heavy-handed).

                                proxy_cache_valid 200 120m;
                        expires 7776000;
                        proxy_cache staticfilecache;
                }

location = /50x.html {
                root   /var/www/nginx-default;
        }

 # No access to .htaccess files.
        location ~ /\.ht {
          deny  all;
        }

    }

ตอนนี้เริ่มเซิร์ฟเวอร์

$ /etc/init.d/apache2 restart  
$/etc/init.d/nginx start

ผลลัพธ์ของเกณฑ์มาตรฐาน

บน Apache Bench การตั้งค่านี้ในทางทฤษฎีสามารถให้บริการ 1833.56 คำขอต่อวินาที

$ ab -n 1000 -c 20 http://yoursite.com/

ข้อความแสดงแทน


คุณพูดถึงการมี nginx จัดการไฟล์คงที่และ apache จัดการไฟล์ php แต่ในบล็อกไฟล์คงที่คุณมี "proxy_pass wordpressapache ;" นั่นหมายความว่า apache กำลังจัดการกับไฟล์สแตติกหรือไม่?
srchulo

0

ดูเหมือนว่าการกำหนดค่า Apache มาตรฐานแม้ว่าจะดูเหมือนว่าบางส่วนถูกขีดออกเพราะดูเหมือนว่า HTML

คุณต้องตรวจสอบสิ่งที่เกิดขึ้นเมื่อเซิร์ฟเวอร์ของคุณตอบสนองช้า คุณไม่ได้บอกรายละเอียดของเซิร์ฟเวอร์ของคุณ แต่คุณพูดถึงความทุ่มเทและ 10k / วันควรจัดการได้อย่างง่ายดาย

  • การแสดงยอดนิยมคืออะไร
  • คอขวดอยู่ที่ไหน CPU, หน่วยความจำ, รอ I / O?
  • กระบวนการ Apache ทำงานอยู่กี่กระบวนการ
  • จำนวนการเชื่อมต่อที่แสดงใน netstat เป็นเท่าไหร่?

คาดเดา CPU น่าจะเป็นคอขวดที่เกิดจาก PHP การใช้ APC และปลั๊กอินการแคช WP เป็นวิธีการที่ดีในการบรรเทาปัญหานี้ซึ่งคุณได้ทำไปแล้ว คุณสามารถลองใช้รูปแบบกระบวนการ "MPM" ของ Apache แทน "Prefork" ตรวจสอบให้แน่ใจว่าคุณมีหน่วยความจำเพียงพอที่จัดสรรให้กับ APC เพื่อให้สามารถแคชสคริปต์ PHP ของคุณและไม่ควรพลาด

นอกจากนี้ยังอาจเป็น MySQL - ดูว่านั่นคือการบีบอัดซีพียูหรือดิสก์

ลองพิจารณาปิด mod_deflate หากคุณเปิดใช้งานมันจะให้ประโยชน์กับเวลาในการโหลด แต่สามารถเพิ่มโหลดของ CPU ได้ อาจจะคุ้มค่าที่จะลอง

ใช้เครื่องมือเช่น 'ล้อม' หรือ 'ab' เพื่อทำเกณฑ์มาตรฐานเซิร์ฟเวอร์ของคุณและดูว่าเซิร์ฟเวอร์ของคุณทำงานช้าแค่ไหน

นี่คือบุ๊คมาร์คบางส่วนของฉันจากการปรับแต่งประสิทธิภาพของเว็บเซิร์ฟเวอร์: http://articles.slicehost.com/2010/5/19/configuring-the-apache-mpm-on-ubuntu

http://www.thebuzzmedia.com/increase-wordpress-performance-on-apache-with-worker-mpm-php-and-mod_fcgid/

http://www.devside.net/articles/apache-performance-tuning

http://www.brandonturner.net/blog/2009/07/fastcgi_with_php_opcode_cache/

แต่คำแนะนำดั้งเดิมของฉันยังคงเหมือนเดิม - ค้นหาว่าคอขวดคืออะไร! มิฉะนั้นคุณจะพยายามปรับปรุงประสิทธิภาพ (และแน่นอนว่าการปรับปรุงประสิทธิภาพจะดีอยู่เสมอ) แต่ไม่ทราบว่าจะเน้นเรื่องใดไป


0

นอกจากนี้ยังเปิดใช้งานโมดูลสถานะเซิร์ฟเวอร์และเยี่ยมชมเพื่อดูว่าเกิดอะไรขึ้น

คุณอาจจะแลกเปลี่ยน คุณเช็คเอาท์ vmstat ในขณะนี้เกิดขึ้น? RAM ขนาด 2GB สำหรับ 80 MaxClients เพียง 25 MB สำหรับแต่ละตัว (สมมติว่ากล่องไม่ได้ทำอะไรอย่างอื่น) MaxClients ของคุณอาจสูงเกินไป วิธีแก้ปัญหานี้ชัดเจน: เพิ่ม RAM มากกว่าหรือต่ำกว่า MaxClients หากบรรทัดคำสั่งตอบสนองช้าเมื่อคุณรีสตาร์ท apache นั่นเป็นข้อบ่งชี้หนึ่งของสถานการณ์นี้

อาจเป็นไปได้ว่าคุณกำลังป้อนลูกค้ามือถือบางคน (หรือลูกค้าอื่น ๆ ในการเชื่อมต่อที่ช้า) ด้วยไฟล์ 'ขนาดใหญ่' ซึ่งจะทำให้สล็อต apache ที่มีอยู่ทั้งหมดของคุณหมด บางทีคุณมี MaxClients น้อยเกินไป การตรวจสอบสถานะเซิร์ฟเวอร์จะบอกคุณว่าไคลเอนต์เหล่านั้นทำอะไรในเวลานั้น ทางออกหนึ่งสำหรับสถานการณ์นี้คือการเพิ่ม MaxClients (แต่นั่นอาจกลายเป็นสถานการณ์ด้านบน) ทางออกที่ดีกว่าสำหรับกรณีนี้คือการติดตั้งตัวเร่ง HTTP หน้า apache (หนึ่งตัวเลือกฟรีคือ perlbal) หากบรรทัดคำสั่งของคุณเป็นเรื่องปกติ ความเร็วเมื่อคุณรีสตาร์ท apache นั่นเป็นข้อบ่งชี้หนึ่งของสถานการณ์นี้


0

การใช้mod_statusเป็นวิธีการดูว่าเกิดอะไรขึ้นในอินสแตนซ์ Apache หลายอินสแตนซ์ แต่โปรดทราบว่ามันจะทำให้ประสิทธิภาพลดลง ดูเหมือนว่าจะกินหน่วยความจำและในกรณีหนึ่งฉันไม่สามารถวินิจฉัยได้ว่าเป็นสาเหตุของการล็อกกระบวนการเดียวในการตั้งค่า reverse-proxy-only ซึ่งไม่มีการให้บริการใด ๆ โดยตรง แน่นอนว่าผู้ใช้เหล่านี้รายงานว่า "ใช้เวลาในการโหลดหน้า" พวกเขาไม่เข้าใจถึงความแตกต่างระหว่าง "มันจะต้องรออีก 10 วินาที" และ "มันจะไม่เสร็จ" เพราะพวกเขามักจะกดปุ่ม Stop ในเบราว์เซอร์หลังจากนั้น (<10) วินาที

ตรวจสอบด้วยว่าคุณกำลังกำหนดค่าตำแหน่งที่ถูกต้องหรือไม่ (ดูได้ง่ายโดยใช้ mod_status เนื่องจากคุณเห็นจำนวนอินสแตนซ์ / กระบวนการ) การกำหนดค่าหุ้นอย่างน้อยใน Ubuntu มีส่วน ifdef'ed ต่อโหมด MPM และง่ายต่อการแก้ไขโหมดผู้ปฏิบัติงานเมื่อคุณใช้งาน prefork (ตามที่แนะนำโดยภูมิปัญญาดั้งเดิมจากความรู้สึกที่คลุมเครือที่ PHP ไม่ได้เป็น threadsafe)

โอ้และที่สำคัญที่สุด: เรียกใช้บนสุดในฐานะผู้ใช้และเฝ้าดูแหล่งที่มาสูงสุด หน่วยความจำ, แผ่นดิสก์, CPU - คุณจะเห็น

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

BTW: 10K นำส่งหน้าต่อวันรวมทั้งไฟล์มีเดียบนเครื่องนี้น่าจะเป็นปัญหาหากพวกเขามาเยี่ยมชมในหนึ่งชั่วโมง


0

คำแนะนำบางอย่างโดยเฉพาะถ้าคุณโฮสต์ไฟล์มีเดียจำนวนมาก:

  • ย้ายสื่อของคุณไปยังอินสแตนซ์ Apache (หรือดีกว่า: nginx) โดยเฉพาะ ไม่มี PHP ไม่มีโมดูลเพียงเซิร์ฟเวอร์ http เปล่าซึ่งจะส่งสื่อเร็วที่สุดเท่าที่จะทำได้
  • แคชแคชแคช! ใช้ปลั๊กอิน super cache บนเวิร์ดเพรส มันช่วยได้มาก
  • ตรวจสอบการตั้งค่า Apache ของคุณที่ส่วนหัว ตรวจสอบว่ารูปภาพและสื่อ "เสถียร" อื่น ๆ มีเวลาหมดอายุเป็นวันที่ห่างไกล & ว่า apache ของคุณส่งคืนรหัส HTTP 304 เมื่อลูกค้าร้องขอ
  • เปิดใช้งาน mod_deflate มันอาจลดประสิทธิภาพโดยลูกค้าจะได้รับเร็วขึ้น
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.