web-dev-qa-db-ja.com

php-fpmとnginx @高CPU使用率?

私のサーバーはDigitalOceanであり、次の計画があります。

2 Core Processor
2 GB Memory

私のウェブサイトは何千人もの訪問者を受け入れていますが、両方のCPUコアは@ 100%です。

enter image description here

問題はphp-fpmnginx: worker processにあるようです。私は自分のサーバーに対して数十の最適化を行いましたが、それでもそれを落ち着かせることができません。

これが私のnginx.confです。

user www-data;
worker_processes 2;
pid /run/nginx.pid;

events {
    worker_connections 2048;
    # multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

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

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

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

    ##
    # Logging Settings
    ##

    access_log off;
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip on;
    gzip_disable "msie6";

    gzip_vary on;
    gzip_proxied expired no-cache no-store private auth;
    gzip_comp_level 2;
    gzip_min_length 1000;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Buffers
    ##

    client_body_buffer_size 10K;
    client_header_buffer_size 1k;
    client_max_body_size 8m;
    large_client_header_buffers 2 1k;

    ##
    # nginx-naxsi config
    ##
    # Uncomment it if you installed nginx-naxsi
    ##

    #include /etc/nginx/naxsi_core.rules;

    ##
    # nginx-passenger config
    ##
    # Uncomment it if you installed nginx-passenger
    ##

    #passenger_root /usr;
    #passenger_Ruby /usr/bin/Ruby;

    ##
    # Virtual Host Configs
    ##

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

Php-fpmのwww.confで有効にしたオプションは次のとおりです。

user = www-data
group = www-data
listen = /var/run/php5-fpm.sock
listen.owner = www-data
listen.group = www-data
pm = ondemand
pm.max_children = 20
pm.start_servers = 2
pm.min_spare_servers = 1
pm.process_idle_timeout = 10s;
pm.max_requests = 500
request_terminate_timeout = 20

サーバーが過負荷にならないようにするにはどうすればよいですか?他に何を変更できますか?

5
user5865490

PHPの実行は、CPU使用率とRAMの点でコストがかかります。PHPインタープリターの呼び出しを回避できるときはいつでも、そうする必要があります。キャッシュは、すべてのユーザーに対してコンテンツがカスタム生成されない限り、これを行います。

私の小さなAWS t2.microは、Nginxキャッシュから毎秒約2500ページを提供できますが、PHP(HHVM)を呼び出す必要がある場合、毎秒約20ページです。このキャッシュにより、毎月の請求額が削減されます。ユーザーごとにページを生成する必要がある場合は、はるかに強力なインスタンスサイズが必要になるため、コストが高くなります。

Microcaching は、急速に変化するサイトに適しているオプションの1つです。わずか1秒のキャッシュで大きなメリットが得られます。もちろん、サイトがゆっくりと変化している場合、キャッシュ時間が増えると、CPU負荷がさらに減少します。

別のオプションは次のとおりです。-より効率的なPHPインタープリターの実行-PHP7またはHHVM-最適化PHPコードの実行-これにより、静的リソースを簡単にオフロードできます。また、ページヘッダー(有効期限とキャッシュステータス)を設定し、CDNを正しく設定すると、ページを直接配信できます。HTMLを含む「すべてをキャッシュする」ように指示するページルールで CloudFlare を使用します。 PHPによって生成されます。その結果、ユーザーのウェブサイトが高速になり、CPUと帯域幅の使用量が削減されます。CloudFlareには、多くの人に適した無料のプランがあります。

負荷分散のためにHAProxyでよく使用されるVarnishなどの他のキャッシュシステムを使用できます。これら2つの製品の間にはいくつかのクロスオーバーがあります。HAProxyはキャッシュを実行でき、Varnishは負荷分散を実行できます。それらについての詳細 ここ

4
Tim