Непонимание как работает fail timeout на самом деле

Vadim Osipov nginx-forum на forum.nginx.org
Вт Май 31 06:28:17 UTC 2016


Здравствуйте
Столкнулся с такой ситуацией, что, видимо, не понимаю в каком случае
срабатывает fail_timeout, max_fails.
Как я это понимаю при моей конфигурации:
например, я делаю 1 запрос http://localhost:80/mem/key10, вычисляется хэш,
ему ставится в соответствие сервер из upstream - это 172.16.11.46:11211 (в
моем случае), и если сервер завис, не отвечает или произошла ошибка
соединения с сервером (машина выключена/не существует), то в течение 30
секунд запросы на эту машину/сервер не идут.
Однако, что получается в действительности - после того, как не удалось
соединиться, начинает ретрансмит через 1 секунду, затем 2, потом (т.к. тут
уже вступает в игру memcached_connect_timeout и ретрансмита между последней
попыткой и новой не будет, т.к. тогда будет разница в 4 сек.) nginx
рехэширует запрос/ключ, и он попадает на работающий сервер, делает запрос и
отдает то, что есть в другом сервере (в моем случае, это 127.0.0.1:11211).

Так какой же вопрос ?
Почему последующий запрос http://localhost:80/mem/key10 не идет сразу на
127.0.0.1:11211, а продолжает те же самые попытки - достучаться до
172.16.11.46:11211 ?

Как проверяли ? 
С помощью tcpdump. 
tcpdump -i any -s 0 -vvv -w /tmp/dump_240_46.pcup

Конфигурация:
upstream  memcached_cluster  {
    server 127.0.0.1:11211 fail_timeout=30s max_fails=1;
    server 172.16.11.46:11211 fail_timeout=30s max_fails=1;     # <---- is
not working now

    hash $uri/3.6;		#    nginx_upstream_hash
    hash_again 1000;	#    nginx_upstream_hash
    keepalive 512;
}

memcached_connect_timeout 5s;

location /mem {
    set $memcached_key "$uri/3.6";
    memcached_pass memcached_cluster;
}

Окружение:
nginx version: nginx/1.4.2
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC) 
TLS SNI support enabled
configure arguments: --user=nginx --group=nginx --prefix=/usr/share/nginx
--sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf
--error-log-path=/var/log/nginx/error.log
--http-log-path=/var/log/nginx/access.log
--http-client-body-temp-path=/var/lib/nginx/tmp/client_body
--http-proxy-temp-path=/var/lib/nginx/tmp/proxy
--http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi
--pid-path=/var/run/nginx.pid --lock-path=/var/lock/subsys/nginx
--with-http_secure_link_module --with-http_random_index_module
--with-http_ssl_module --with-http_realip_module --with-http_addition_module
--with-http_sub_module --with-http_dav_module --with-http_flv_module
--with-http_gzip_static_module --with-http_stub_status_module
--with-http_perl_module --with-http_xslt_module --with-debug --with-mail
--with-mail_ssl_module --with-cc-opt='-O2 -g -pipe -Wall
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector
--param=ssp-buffer-size=4 -m64 -mtune=generic' --with-ipv6
--add-module=/root/rpmbuild/BUILD/nginx-1.4.2/nginx-push-stream-module
--add-module=/root/rpmbuild/BUILD/nginx-1.4.2/nginx_upstream_hash
--add-module=/root/rpmbuild/BUILD/nginx-1.4.2/nginx-memcached-hash-pass

OS: CentOS release 6.6 (Final)
Kernel: Linux tve-lab-240 2.6.32-504.12.2.el6.x86_64 #1 SMP Wed Mar 11
22:03:14 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux

Документация по стороннему модулю:
https://github.com/evanmiller/nginx_upstream_hash
http://hb.321key.org/hb/nginx-1.3.8/03A6EA3ED31C437BB3DF5902E32F2E68/4B83DA8DC7.htm

Posted at Nginx Forum: https://forum.nginx.org/read.php?21,267237,267237#msg-267237



Подробная информация о списке рассылки nginx-ru