Ich kann mit der Funktion „HTTP-Antwort-Add-Header“ neue Header in Haproxy hinzufügen und dies wird erfolgreich durchgeführt, da ich diese hinzugefügten Header in meinem HTTP-Paket sehen kann, wenn ich Wireshark verwende.
Das Problem ist, dass ich sie nicht erfassen kann. Ich verwende die Funktion „Antwortheader erfassen“ und damit kann ich allgemeine Header wie „Content-Type“ oder „Connection“ erfassen und protokollieren, aber für hinzugefügte Header funktioniert es nicht.
dies ist meine Konfigurationsdatei haproxy.cfg:
global
log /dev/log local0
log /dev/log local1 notice
chroot /var/lib/haproxy
stats socket /run/haproxy/admin.sock mode 660 level admin
stats timeout 30s
user haproxy
group haproxy
daemon
defaults
log global
mode http
option httplog
option dontlognull
option http-server-close
timeout http-request 5000
timeout connect 5000
timeout client 50000
timeout server 50000
frontend localnodes
bind 10.0.0.16:80
mode http
# Table definition
stick-table type ip size 100k expire 30s store conn_cur
tcp-request connection track-sc1 src
capture response header X-Test-One len 10
capture response header X-Test-Two len 10
capture response header Content-Type len 10
capture response header Connection len 10
default_backend nodes
backend nodes
mode http
balance roundrobin
http-response add-header X-Test-One %Ts
http-response add-header X-Test-Two %T
server web01 123.123.22.22:2222 check maxconn 500
listen stats *:1936
stats enable
stats uri /
stats hide-version
stats auth notthelogin:notthepassword
Und wenn ich eine HTTP-Anfrage mache, steht Folgendes in meiner Protokolldatei:
Oct 7 11:12:38 localhost haproxy[20304]: 10.0.0.20:34316 [07/Oct /2015:11:12:38.972] localnodes nodes/web01 0/0/0/1/1 200 11378 - - ---- 14/14/0/0/0 0/0 {||text/html|close} "GET / HTTP/1.0"
Im Protokoll können wir mit "{||text/html|close}" deutlich sehen, dass die Standardheader gut erfasst werden, nicht jedoch die beiden hinzugefügten Header, die zwischen den "|" leer erscheinen. Sie sind jedoch im HTTP-Paket enthalten, wie wir mit Wireshark sehen können.
Wireshark-Screenshot mit benutzerdefinierten Headern
Kann mir bitte jemand helfen? Ich kann das Problem nicht herausfinden und hänge schon seit zwei Tagen daran :/
Danke :)