我想从主机为在 VM 中运行的两个或多个 Web 应用程序(不同的端口和同一端口下的不同目录中的某个时间)提供服务,因为我需要用户先登录,然后才能访问我无法使用的那些应用像 Nginx 或 Apache 这样的静态代理。

所以这是我的情况:

192.168.1.1:是主机ip
192.168.1.2:是VM ip

在虚拟机内部,我有这个:

192.168.1.2/owncloud : owncloud 地址
192.168.1.2:8080 : 另一个应用程序
192.168.1.2:8888 : 第三个应用程序

我想要这个:

192.168.1.1/app1 --> 192.168.1.2/owncloud
192.168.1.1/app2 --> 192.168.1.2:8080
192.168.1.1/app2 --> 192.168.1.2:8

我曾尝试使用 golang httputil.ReverseProxy 来实现此路由,但没有取得多大成功:我的代码基于此工作:gist

package main


import(

    "log"

    "net/url"

    "net/http"

    "net/http/httputil"

)


func main() {

    remote, err := url.Parse("http://192.168.1.2:8080")

    if err != nil {

            panic(err)

    }


    proxy := httputil.NewSingleHostReverseProxy(remote)

    http.HandleFunc("/app2", handler(proxy))

    err = http.ListenAndServe(":80", nil)

    if err != nil {

            panic(err)

    }

}


func handler(p *httputil.ReverseProxy) func(http.ResponseWriter, *http.Request) {

    return func(w http.ResponseWriter, r *http.Request) {

        log.Println(r.URL)

        r.URL.Path = "/"                

            p.ServeHTTP(w, r)

    }

}

我更改了 vm ip 地址:192.168.1.2 而不是 192.168.1.1