mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-01-13 09:11:06 +00:00
58f10d7478
The new parser uses an FSM to strictly follow RFC2616. Headers are indexed and parsed only once they're all available. That way, complex regexes make more sense. HTTP processing is now performed in several phases by calling multiple functions, making the code cleaner and easier to read. Note that req[i]pass does not work anymore because it would require that we mark a header to be ignored. What is really needed is to have the ability to add an exception to a matching (match xx except yy). Several bugs have been fixed in appsession during the conversion to the new FSM (method length and recovery on malloc errors). The code does build and work with the debug examples, but is not usable yet to connect to anything as it does not forward the requests yet.
171 lines
6.2 KiB
Plaintext
171 lines
6.2 KiB
Plaintext
* x-forwarded-for
|
|
* implémenter l'option "log global" au niveau proxy pour utiliser les logs
|
|
globaux.
|
|
* matching case-insensitive
|
|
* implémenter outgoing addr
|
|
* loguer t_cnx, t_data, t_total
|
|
+ factoriser la fonction de log (send_log = send_syslog+warning+alert)
|
|
+ désactivation du keep-alive (suppression des ^Connection: et ajout des Connection: close)
|
|
-> 4 lignes (2 del, 2 add) suffisent.
|
|
+ ne pas loguer certaines adresses IP sources
|
|
-> pour les health-checks uniquement -> pas de log pour les requêtes
|
|
vides (option dontlognull)
|
|
- mesurer le tps consommé entre deux select, et fournir la conso CPU :
|
|
%cpu = 100 * (tpreselect(n+1)-tpostselect(n)) / (tpreselect(n+1)-tpreselect(n))
|
|
* implémenter limitation fd dans la conf : setrlimit(RLIMIT_NOFILE, ...)
|
|
- implémenter core/no-core dans la conf : setrlimit(RLIMIT_CORE, ...)
|
|
- optimiser les regex pour accélérer les matches :
|
|
- compter les matches
|
|
- si match(n) & ([n].cpt > [n-1].cpt) & ([n].action == [n-1].action), swap(n,n-1)
|
|
- régulièrement, diviser tous les compteurs (lors d'un dépassement par exemple)
|
|
- filtrage sur l'adresse IP source, et stocker le pointeur sur la dernière regex
|
|
matchée dans la "session" pour accélérer les regex.
|
|
- gestion keep-alive
|
|
|
|
+ handle parametrable HTTP health-checks replies
|
|
- differentiate http headers and http uris
|
|
- support environment variables in config file
|
|
- support keep-alive
|
|
- support SSL
|
|
|
|
===================== demandes ==========================
|
|
ok> 1) écoute sur une plage de ports :
|
|
ok> listen XXX 1.2.3.4:21000-21060
|
|
ok>
|
|
ok> 2) écoutes multiples :
|
|
ok> listen XXX 1.2.3.4:21000
|
|
ok> bind 2.3.4.5:21001
|
|
ok> bind 2.3.4.5:21000-21060
|
|
ok>
|
|
ok> => on en arrive à ceci :
|
|
ok>
|
|
ok> listen XXX [ address:port ]
|
|
ok> bind addr:plage-port[,[addr:]plage-port]*
|
|
ok> bind ...
|
|
ok> ...
|
|
ok>
|
|
ok> => proxy->listen_fd et proxy->listen_addr doivent être
|
|
ok> mis dans des listes
|
|
ok> => OK pour listen, implémenter le BIND.
|
|
ok>
|
|
ok> 3) reconnexion sur le même port sur le serveur :
|
|
ok>
|
|
ok> server XXX 1.2.3.4[:port]
|
|
ok> si <port> n'est pas spécifié, on utilise le même port que celui qui a reçu
|
|
ok> la connexion. Dans ce cas, il faut pouvoir forcer le port du health-check
|
|
ok> par un nouveau parametre "port".
|
|
ok>
|
|
ok> => ça permet les forwardings de plages :
|
|
ok>
|
|
ok> listen XXX
|
|
ok> bind 1.2.3.4:10000-11000
|
|
ok> server 1.2.3.5
|
|
ok>
|
|
4) paramètres par défaut :
|
|
créer une section "defaults" qui précise les paramètres par défaut pour les
|
|
sections suivantes, concernant les paramètres suivants :
|
|
ok- les logs
|
|
ok- les modes (tcp/http)
|
|
ok- le balancing (round-robin/source)
|
|
ok- les time-outs
|
|
ok- maxconn
|
|
ok- redisp
|
|
ok- les options
|
|
ok- le retry
|
|
ok- les checks
|
|
ok- les cookies/captures
|
|
- les options des serveurs ?
|
|
- les filtres et regex ?
|
|
|
|
* implémenter "balance source" pour faire un hash sur la source.
|
|
permettre de spécifier un masque sur lequel s'applique le hachage,
|
|
ainsi qu'une option pour hacher en fonction de l'adresse dans le
|
|
champ "x-forwarded-for". Problème pour le support des pannes: ce
|
|
type de hash est utile là où la persistence par cookie ne peut pas
|
|
s'appliquer, donc comment faire pour assurer un maximum de persistence
|
|
en cas de panne ?
|
|
|
|
6) possibilité d'un process séparé par listen :
|
|
listen XXX
|
|
fork [ group_id ]
|
|
|
|
le fait de spécifier group_id fera que toutes les instances utilisant le
|
|
même identifiant de groupe seront gérées par un même processus.
|
|
|
|
-> plus souple et plus compréhensible de faire des sections par processus,
|
|
ce qui résoud également le cas ci-dessous. Ex:
|
|
process_group X
|
|
nbproc X
|
|
uid X
|
|
chroot X
|
|
listen ...
|
|
|
|
7) gérer un chroot/uid/gid différents par process :
|
|
listen XXX
|
|
chroot /truc
|
|
uid 123
|
|
gid 456
|
|
|
|
8) beaucoup de paramètres pourraient être spécifiques aux serveurs et non
|
|
aux instances. Exemples :
|
|
* adresse IP source pour atteindre le serveur
|
|
- méthode de health-check (proto, ...)
|
|
* méthode de health-check (port)
|
|
- poids
|
|
- alerte en cas de disparition
|
|
- le nombre max de sessions à lui envoyer
|
|
|
|
ok> 9) ajouter des paramètres optionnels à l'option "httpchk" permettant
|
|
ok> de forcer la méthode, la version HTTP et des headers.
|
|
ok> ex: option httpchk -> OPTIONS / HTTP/1.0
|
|
ok> option httpchk /test -> OPTIONS /test HTTP/1.0
|
|
ok> option httpchk HEAD / HTTP/1.0\nHost:\ www -> tel quel
|
|
|
|
Todo for 1.1
|
|
============
|
|
* "no more server" alert
|
|
* config check
|
|
- anti-flapping
|
|
|
|
Todo for 1.2
|
|
============
|
|
- direct <server> <regex> <match>
|
|
- new config syntax allowing braces to be able to shorten lines
|
|
- insert/learn/check/log unique request ID, and add the ability
|
|
to block bad responses.
|
|
- IPv6 :
|
|
* listen [ip4.ip4.ip4.ip4]:port[-port]
|
|
* listen [ip6::...ip6]/port[-port]
|
|
- server xxx ipv4 | ipv4: | ipv4:port[-port] | ipv6/ | ipv6/port[-port]
|
|
* appcookie
|
|
* weighted round robin
|
|
- option to shutdown(listen_sock) when max connections reached
|
|
* epoll
|
|
- replace the event scheduler with an O(log(N)) one. The timer queue will
|
|
need a tree with a known end (to speed up queueing of latest events), and
|
|
no entry for eternity.
|
|
- refine memory management so that the request buffer is only allocated in
|
|
cli_read() and response buffer during srv_read(). This would protect against
|
|
attacks with thousands connections : 20000 connections consume 340 MB RSS and
|
|
1.3 GB VSZ on Linux. Data should be in a separate buffer to prevent any
|
|
activity on the buffer's pointers from touching the buffer page itself.
|
|
- make buffer size configurable in global options
|
|
* monitor number of simultaneous sessions in logs (per srv/inst/global)
|
|
* ignore leading empty lines in HTTP requests
|
|
+ limit the per-server number of sessions and queue incoming connections
|
|
=> still needs refinement (actions at servers UP/DOWN, timeouts)
|
|
- new 'timeout' keyword to set all timeouts (including the queue)
|
|
- ability to intercept an URI to report statistics
|
|
- ability to intercept an URI to return 404
|
|
- embedded error pages loaded in memory at startup time (eg: for expired time
|
|
in connection queue)
|
|
|
|
|
|
TODO for 1.3
|
|
============
|
|
- check all copyrights
|
|
- fix Makefile.bsd
|
|
- separate inline functions to put them in files covered by GPL
|
|
- implement HTTP status 414 - request URI too long
|
|
|