ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Smart load balancing


  • To: nginx-ru@xxxxxxxxx
  • Subject: Re: Smart load balancing
  • From: Andrey Zloy <andrey.zloy@xxxxxxxxx>
  • Date: Wed, 20 Jan 2010 18:58:20 +0300
  • Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:received:in-reply-to:references :date:message-id:subject:from:to:content-type :content-transfer-encoding; bh=4nXQZzgGESCoQfNWI7J/Dp4mMsMzwMtus79iXoLJ+2Q=; b=CPWBkTNU2Ru6oOt0AE6FxQi2nufDnUUAb46F3UNOToYDVOzXTj/GkWE4Ddmome6gv9 BPv7RZvS+4laKo59LzLYcdbH/reXIkDs9cGBznRvk4MNUoWFs2r3R33gnSitpbS7v7cT 5aVCyopUsR0mpszIEClAGLYHcJV0r5O7o/C+E=
  • Domainkey-signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :content-type:content-transfer-encoding; b=C234KY2nb3AEi175SxL10EKiAiyeDd3a0rbJ8D0XBRcUN0vd8Y5TWrFIVp0hBKY/6g AytRuEmO+kzDQPS/OhudoyH/fpD+DgrLGJZgDNIb8DTrwKzYDBrJ6jvQqJjcXVsUfXLF jZVYy1cVt3B8FXLJKSClNcxGOa6eI1Ogo+lxY=
  • In-reply-to: <d4574cb31001200537s14b8c0f4rf618b6c1920923dc@xxxxxxxxxxxxxx>
  • References: <d4574cb31001200537s14b8c0f4rf618b6c1920923dc@xxxxxxxxxxxxxx>

> Вопросы:
> 1. Можно ли это реализовать? Я не очень пока понимаю - что можно
> сделать стандартными средствами, что - с использованием перла. А,
> может, что-то нельзя вообще. Вот пункт 8 - можно? А 2?
> 2. Поделитесь, пожалуйста, примерами конфигов, ну или ссылками на
> соответствующие разделы документации.

Можно. Для выбора бэкэнда можно истользовать алгоритм от мемкеша.
Требует установленного модуля перла String::CRC32 (не помню есть ли он
по дефолту)

http {
...
perl_set $serv_index 'sub {
        use String::CRC32;
        use nginx;
        my $r = shift;
        $r =~ /super_cookie=([^;]+?)/;
        my $my_cookie = $1;
        my $serv_index = (((crc32($my_cookie) >> 16) & 0x7fff) % 2); #
где 2 это кол-во бэкэндов

        return $serv_index;
    }';
....
}

server {
..
       set $serv_index = $http_cookie;
       if ($serv_index = 0){
                proxy_pass  127.0.0.1;
        }
        if ($serv_index = 1){
                proxy_pass  192.168.0.29;
        }
...
}

Аналогично можно сделать проверку на экспайр и md5 для валидности.
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.