go proxy 实现反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
代理代码
package main
import (
"fmt"
"net/http" "net/http/httputil" "net/url")
func sayHello(w http.ResponseWriter, r *http.Request) {
//这里定义代理目标地址,这里定义到本机9091端口
u, _ := url.Parse("http://127.0.0.1:9091/")
proxy := httputil.NewSingleHostReverseProxy(u)
proxy.ServeHTTP(w, r)
}
func main() {
http.HandleFunc("/hello", sayHello)
err := http.ListenAndServe(":9090", nil)
if err != nil {
fmt.Println("HTTP server failed,err:", err)
return
}
}
最终目标代码
package main
import (
"fmt"
"net/http")
func sayHello(w http.ResponseWriter, r *http.Request) {
fmt.Println("hello,这里是s2服务里的say Hello")
}
func main() {
http.HandleFunc("/hello", sayHello)
err := http.ListenAndServe(":9091", nil)
if err != nil {
fmt.Println("HTTP server failed,err:", err)
return
}
}
通过以上代码,可以看出,我是把9090的端口sayHello
函数,代理到了本机9091端口的sayHello
函数。
本作品采用《CC 协议》,转载必须注明作者和本文链接
之前也捣鼓了一下golang 的反向代理 github.com/hezhizheng/go-reverse-p...
这样代理本地端口应该不会有问题,如果被代理的serve有限制HOST的请求,这段代码应该直接会抛错,详情可以看下 liqiang.io/post/implement-reverse-...