मुझे HAproxy से समस्या है।
मैं लोड बैलेंसर के रूप में HAproxy का उपयोग करता हूं जो आने वाले http अनुरोधों को 5 वेब सर्वरों पर वितरित करता है। सामान्य रूप से क्लाइंट रिक्वेस्ट को लोडबॉलर के आईपी के साथ वेब सर्वर पर भेज दिया जाता है। लेकिन मुझे क्लाइंट आईपी या असली आईपी चाहिए जो वेब सर्वर से कुछ अनुरोध करते हैं। क्योंकि हमें असली ग्राहक के आईपी को लॉग इन करना होगा।
मैं वेब सर्वर पर क्लाइंट के आईपी प्राप्त करने की कोशिश करता हूं, लेकिन अब तक मैं सफल नहीं हो सकता। हमेशा मुझे लोड बैलेंसर का आईपी दिखाई देता है।
मैं x-फॉरवर्ड-फॉर ऑप्शन का उपयोग करता हूं लेकिन यह समस्या हल नहीं होती है। उसके बाद मुझे एक और विकल्प मिला " सोर्स 0.0.0.0:80 यूज़र्स क्लाइंटिप " मैंने ऐसा किया था, मैं HAEExy को USE_TPROXY विकल्प के साथ फिर से जोड़ देता हूं लेकिन कुछ भी नहीं बदलता है। वास्तविक ग्राहक के आईपी सीखने के लिए मैं क्या कर सकता हूं।
मेरा लिनक्स कर्नेल संस्करण 2.6.32-34 है मेरा मतलब है कि कर्नेल पारदर्शी प्रॉक्सी का समर्थन करता है। और मैं UBUNTU 10.4 LTS का उपयोग करता हूं
मेरी विन्यास फाइल यहाँ है
global
maxconn 100000
uid 99
gid 99
daemon
defaults
option forwardfor except 127.0.0.1
mode http
(1)source 0.0.0.0:80 interface hdr_ip(x-forwarded-for,-1)
(2)source 0.0.0.0:80 usesrc clientip
contimeout 5000
clitimeout 50000
srvtimeout 50000
listen myWeb 0.0.0.0:80
mode http
balance source
option forwardfor header X-Client
option http-server-close
stats enable
stats refresh 10s
stats hide-version
stats scope .
stats uri /lb?stats
stats realm LB2\ Statistics
stats auth admin:xXx
server S1 192.168.1.117:80 check inter 2000 fall 3
server S2 192.168.1.116:80 check inter 2000 fall 3
server S3 192.168.1.118:80 check inter 2000 fall 3
(1) (2) HAproxy का परीक्षण करते समय मैंने इन दो लाइनों में से एक का उपयोग किया।
क्या कोई मुझे उन ग्राहकों के वास्तविक आईपी सीखने में मदद करता है जो हमारे सर्वर से अनुरोध कर रहे हैं?