package proxy import ( . "bp.jydev.jianyu360.cn/BaseService/gateway/common/gatecode" "bp.jydev.jianyu360.cn/BaseService/gateway/core/logs" "bp.jydev.jianyu360.cn/BaseService/gateway/core/node" "bp.jydev.jianyu360.cn/BaseService/gateway/core/proxy/broker" "bp.jydev.jianyu360.cn/BaseService/gateway/core/proxy/middleware" "bp.jydev.jianyu360.cn/BaseService/gateway/core/proxy/proxyClient" "bp.jydev.jianyu360.cn/BaseService/gateway/core/router" "fmt" "github.com/gogf/gf/v2/frame/g" "github.com/gogf/gf/v2/net/ghttp" "github.com/gogf/gf/v2/os/gcfg" "github.com/gogf/gf/v2/os/gctx" "net/http" ) var bManager = broker.InitBroker() var routerManager *router.Manager // InitGateWayServer 初始化网关服务 func InitGateWayServer() *ghttp.Server { initCtx := gctx.New() //创建节点,并持续观察节点变化 watchNode := node.NewNode(gcfg.Instance().MustGet(initCtx, "system.etcdListen", nil).Strings()...) go watchNode.NewWatcher(initCtx, bManager) //初始化可访问路由 var err error routerManager, err = router.InitRouterManager() if err != nil { logs.GInfo.Error(initCtx, err) } gateWayServer := g.Server() //关闭系统自带请求日志 gateWayServer.SetLogger(logs.GInfo) gateWayServer.SetErrorLogEnabled(false) //注册中间件 gateWayServer.Use(middleware.ErrorHandler) //错误拦截 gateWayServer.Use(func(r *ghttp.Request) { r.SetError(routerManager.InfusionContext(r)) //context注入全局信息 r.Middleware.Next() }) gateWayServer.Use(middleware.FilterHandler) //权限过滤 //加载代理客户端 proxyClient.ReLoadClient() //注册代理 gateWayServer.BindHandler("POST:/*", proxyHandler) return gateWayServer } // proxyHandler 网关代理Handler处理,完成所有校验后 var proxyHandler = func(r *ghttp.Request) { if r.GetError() != nil { return } gCtx := router.GetGContext(r.GetCtx()) //获取服务地址 proxyAddr, err := bManager.GetServerAddr(gCtx.RouterRule.MiddleCode, r.GetClientIp()) if err != nil { r.SetError(err) return } //代理地址存入ctx中 gCtx.ServerAddr = proxyAddr.String() router.UpdateGContext(r, gCtx) errHandel := func(hw http.ResponseWriter, hr *http.Request, err error) { r.SetError(NewErrorWithCode(GATEWAY_PROXY_ERR, fmt.Sprintf("代理异常:%s err:%v \n", gCtx.ServerAddr, err.Error()))) } proxyClient.CreateCustomProxyClient(proxyAddr, errHandel).ServeHTTP(r.Response.ResponseWriter, r.Request) }