反向代理,haproxy不转发主机



我试图配置在一台服务器上运行的HAproxy,以将请求转发到我在appfog上运行的一些应用程序,但它已停止工作。我已经检查了我的配置,但我找不到问题。

我怀疑主机信息没有被正确转发,因为当我输入domain1.com时,我在appfog上被路由到domain1.app.com,但服务器抛出404。

我的配置文件-

global
        maxconn   4096
        user      haproxy
        group     haproxy
        daemon
        log       127.0.0.1 local0  info
        log       127.0.0.1 local1  notice
defaults
        log     global
        mode    http
        option  httplog
        option  dontlognull
        option  originalto
        option  forwardfor
    stats   enable
    stats   auth domain1:xxxxxx
        option  httpclose
        retries 3
        option  redispatch
        maxconn        2000
        contimeout      5000
        clitimeout      50000
        srvtimeout      50000
backend domain1_at_appfog
        reqirep ^Host: domain2.com Host: domain2.web.app.com
        server appfog1 domain2.web.app.com:80
backend domain2_at_appfog
        reqirep ^Host: domain1.com Host: domain1.app.com
        server appfog2 domain1.app.com:80 
backend local_host_site
        server this1 127.0.0.1:8080
frontend superliciousLove *:80
        acl www_domain1 hdr_dom(host)  -i www.domain1.com
    acl local_host url_sub www2
    use_backend domain1_at_appfog if www_domain1
        use_backend local_host_site if local_host
        default_backend   domain1_at_appfog

根据所提供的示例,如果它是准确的,那么问题就在这里:

backend domain1_at_appfog
    reqirep ^Host: domain2.com Host: domain2.web.app.com
    server appfog1 domain2.web.app.com:80

您的ACL正在检查www.domain1.com,并路由到backend domain1_at_appfog。但是,您正在对domain2.com而不是domain1.com进行替换,并且appfog只看到domain1.com而不是重新映射的主机名。

如果您需要后端支持多个域,您可以更改reqirep的使用,将所有匹配的主机替换为appfog主机:

backend domain1_at_appfog
    reqirep ^Host: Host: domain1.web.app.com
    server appfog1 domain1.web.app.com:80
backend domain2_at_appfog
    reqirep ^Host: Host: domain2.app.com
    server appfog2 domain2.app.com:80 

最新更新