lighttpd:后端超载

lighttpd:后端超载

我有一个高流量的网站,我想维护它,但是不时地会在流量高峰时遇到以下问题:

 (mod_fastcgi.c.2900) backend is overloaded; we'll disable it for 2 seconds and send the request to another backend instead: reconnects: 0 load: 2541

当前统计数据如下:

absolute (since start)
Requests    15 kreq
Traffic 20.02 Mbyte
average (since start)
Requests    81 req/s
Traffic 106.24 kbyte/s
average (5s sliding average)
Requests    94 req/s
Traffic 99.23 kbyte/s

3952 connections

该网站本身是一个非常简单的 PHP 网站,不涉及 MySQL。我确实安装并配置了 APC。

我已将建议的更改添加到 /etc/sysctl.conf:

# These ensure that TIME_WAIT ports either get reused or closed fast.
net.ipv4.tcp_fin_timeout = 1
net.ipv4.tcp_tw_recycle = 1

# TCP memory
net.core.rmem_max = 16777216
net.core.rmem_default = 16777216
net.core.netdev_max_backlog = 262144
net.core.somaxconn = 262144

net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_synack_retries = 2
net.ipv4.tcp_syn_retries = 2
net.ipv4.tcp_max_syn_backlog = 2048
net.ipv4.tcp_max_syn_backlog = 262144
net.ipv4.tcp_max_orphans = 262144

我的 lighttpd.conf 如下所示:

server.max-fds = 12000
server.max-keep-alive-requests = 0
server.event-handler = "linux-sysepoll"
server.max-connections = 10000

fastcgi 配置:

## Start an FastCGI server for php (needs the php5-cgi package)
fastcgi.server    = ( ".php" =>
    ((
            "bin-path" => "/usr/bin/php-cgi",
            "socket" => "/tmp/php.socket",
            "max-procs" => 14,
            "bin-environment" => (
                    "PHP_FCGI_CHILDREN" => "30",
                    "PHP_FCGI_MAX_REQUESTS" => "100000"
            ),
            "bin-copy-environment" => (
                    "PATH", "SHELL", "USER"
            ),
            "broken-scriptfilename" => "enable"
    ))
)

服务器利用率:

top - 08:04:26 up 97 days, 15:14,  1 user,  load average: 0.10, 0.08, 0.04
Tasks: 570 total,   3 running, 567 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.9%us,  0.2%sy,  0.0%ni, 98.5%id,  0.3%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   4056176k total,  3716120k used,   340056k free,   631600k buffers
Swap:   995988k total,    15544k used,   980444k free,  1631236k cached

我尝试了各种方法。我知道 mac 处理器过高通常不太好,但如果我将其调低,服务器就会立即开始抛出 500 错误。

有谁能建议如何调整才能保持网站稳定?在一台服务器上支持这种级别的流量是否可行?

答案1

“后端已超载” - 这意味着 14 个max-procs后端中有一个已超载(lighttpdmax-procs通过在套接字文件名后附加“-[number]”为每个后端创建不同的套接字)。

我会选择较低的 max-procs 数量,并增加 PHP_FCGI_CHILDREN,例如"max-procs" => 2"PHP_FCGI_CHILDREN" => "210",或 4 和 100(或 1 和 400)。

这应该会降低其中一个后端“已满”而另一个后端仍能接受请求的可能性。但我不确定 APC 是否能很好地随 PHP_FCGI_CHILDREN 的数量而扩展。

另一种方法是使用spawn-fcgi结合多监视(multiwatch 执行'max-procs'部分) - 在这个解决方案中,所有 php 后端都在同一个套接字上,因此您不会遇到平衡问题。

答案2

我建议在 lighttpd 前面放置某种缓存解决方案,它可以从缓存中处理请求,而不会每次都击中后端,因为据我所知,你没有完全使用内存。

您可以尝试一下 Varnish。

Varnish 是一款 Web 应用程序加速器。将它安装在 Web 应用程序前面,可以显著提高 Web 应用程序的速度。

以下是相同内容的链接 -Varnish 缓存

相关内容