File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / lighttpd / doc / outdated / proxy.txt
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Mon Oct 14 10:32:48 2013 UTC (11 years, 5 months ago) by misho
Branches: lighttpd, MAIN
CVS tags: v1_4_41p8, v1_4_35p0, v1_4_35, v1_4_33, HEAD
1.4.33

    1: ===================
    2: the Proxy Interface
    3: ===================
    4: 
    5: -----------------
    6: Module: mod_proxy
    7: -----------------
    8: 
    9: :Author: Jan Kneschke
   10: :Date: $Date: 2013/10/14 10:32:48 $
   11: :Revision: $Revision: 1.1.1.1 $
   12: 
   13: :abstract:
   14:   The proxy module a simplest way to connect lighttpd to
   15:   java servers which have a HTTP-interface.
   16: 
   17: .. meta::
   18:   :keywords: lighttpd, Proxy
   19: 
   20: .. contents:: Table of Contents
   21: 
   22: Description
   23: ===========
   24: 
   25: ...
   26: 
   27: Options
   28: =======
   29: 
   30: lighttpd provides the Proxy support via the proxy-module
   31: (mod_proxy) which provides 2 options in the config-file:
   32: 
   33: :proxy.debug:
   34:   a value between 0 and 65535 to set the debug-level in the
   35:   Proxy module. Currently only 0 and 1 are used. Use 1 to
   36:   enable some debug output, 0 to disable it.
   37: 
   38: :proxy.balance:
   39:   might be one of 'hash', 'round-robin' or 'fair' (default).
   40: 
   41:   'round-robin' choses another host for each request, 'hash'
   42:   is generating a hash over the request-uri and makes sure
   43:   that the same request URI is sent to always the same host.
   44:   That can increase the performance of the backend servers
   45:   a lot due to higher cache-locality. 'fair' is the normal
   46:   load-based, passive balancing.
   47: 
   48: :proxy.server:
   49:   tell the module where to send Proxy requests to. Every
   50:   file-extension can have its own handler. Load-Balancing is
   51:   done by specifying multiple handles for the same extension.
   52: 
   53:   structure of proxy.server section: ::
   54: 
   55:     ( <extension> =>
   56:       (
   57:         ( "host" => <string> ,
   58:           "port" => <integer> ),
   59:         ( "host" => <string> ,
   60:           "port" => <integer> )
   61:       ),
   62:       <extension> => ...
   63:     )
   64: 
   65:   :<extension>: is the file-extension or prefix (if started with "/")
   66:                 might empty to match all requests
   67:   :"host":      is ip of the proxy server
   68:   :"port":      is tcp-port on the "host" used by the proxy
   69:                 server (default: 80)
   70: 
   71:   e.g.: ::
   72: 
   73:     proxy.server = ( ".jsp" =>
   74:   		       ( (
   75: 		           "host" => "10.0.0.242",
   76: 		           "port" => 81
   77: 		         ) )
   78: 		     )
   79: 
   80: Example:
   81: ========
   82: 
   83: Using lighttpd + mod_proxy in front of 8 Squids which handle the
   84: caching of dynamic content for you. All requests for the host
   85: www.example.org should be forwarded to the proxy. All proxies
   86: listen on port 80 for requests. ::
   87: 
   88:   $HTTP["host"] == "www.example.org" {
   89:     proxy.balance = "hash"
   90:     proxy.server  = ( "" => ( ( "host" => "10.0.0.10" ),
   91:                               ( "host" => "10.0.0.11" ),
   92:                               ( "host" => "10.0.0.12" ),
   93:                               ( "host" => "10.0.0.13" ),
   94:                               ( "host" => "10.0.0.14" ),
   95:                               ( "host" => "10.0.0.15" ),
   96:                               ( "host" => "10.0.0.16" ),
   97:                               ( "host" => "10.0.0.17" ) ) )
   98:   }
   99: 
  100: If one of the hosts goes down the all requests for this one server are
  101: moved equally to the other servers. If you want to know more about
  102: the algorithm used here google for 'Microsoft CARP'.
  103: 
  104: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>