在实际的使用过程遇到这样一个需求,由于测试环境比较多,每个测试环境都是独立运行的,但是又只有一个域名来进行访问。这样在haproxy进行转发的时候就需要前端发送一个特定的头部信息来对响应的请求转发到相应的后端服务器。
这样设计的话就需要设置一个map文件来记录响应的头部对应的后端服务器地址。
其他的配置文件就不再给出,只给出响应的配置:
map文件serverip.map信息:
dev1 192.168.11.10
dev2 192.168.11.11
haproxy配置信息:
...
frontend TEST
...
acl acl_domain_name hdr(host) -i test.example.com
http-request add-header x-proxy-serverip %[req.hdr(x-proxy-env),lower,map(/etc/haproxy/serverip.map)] if acl_domain_name
http-request set-dst req.hdr(x-proxy-serverip) if acl_domain_name
http-request set-dst-port int(80) if acl_domain_name
use_backend SERVER_TEST if acl_domain_name
backend SERVER_TEST
server test 0.0.0.0:0
注意:如果使用keep-alive,将会有缓存。
本文介绍了如何在多测试环境场景下,通过haproxy配置实现单一域名访问下,根据前端发送的特定头部信息将请求转发至对应的后端服务器。配置中,关键在于创建一个map文件记录头部信息与后端IP的映射,并在haproxy配置中使用该映射进行请求转发。同时,如果开启keep-alive,系统会利用缓存提高效率。
650





