proxyServer.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package proxy
  2. import (
  3. log "app.yhyue.com/moapp/jylog"
  4. "fmt"
  5. "github.com/gogf/gf/v2/frame/g"
  6. "github.com/gogf/gf/v2/net/ghttp"
  7. "github.com/gogf/gf/v2/net/gtrace"
  8. "github.com/gogf/gf/v2/os/gctx"
  9. . "jygit.jydev.jianyu360.cn/dataservice/tripartite_gateway/common/gatecode"
  10. "jygit.jydev.jianyu360.cn/dataservice/tripartite_gateway/core/proxy/middleware"
  11. "jygit.jydev.jianyu360.cn/dataservice/tripartite_gateway/core/proxy/proxyClient"
  12. "jygit.jydev.jianyu360.cn/dataservice/tripartite_gateway/core/router"
  13. "net/http"
  14. "net/url"
  15. )
  16. var routerManager *router.Manager
  17. const errTryTime = 10 //错误尝试
  18. // InitGateWayServer 初始化网关服务
  19. func InitGateWayServer(initCtx gctx.Ctx) *ghttp.Server {
  20. initCtx, span := gtrace.NewSpan(initCtx, "InitGateWayServer")
  21. defer span.End()
  22. //初始化可访问路由
  23. var err error
  24. routerManager, err = router.InitRouterManager()
  25. if err != nil {
  26. log.WithContext(initCtx).Errorln(err)
  27. }
  28. gateWayServer := g.Server()
  29. //关闭系统自带请求日志
  30. gateWayServer.SetLogger(g.Log())
  31. gateWayServer.SetErrorLogEnabled(false)
  32. //注册中间件
  33. gateWayServer.Use(middleware.ErrorHandler) //错误拦截
  34. gateWayServer.Use(func(r *ghttp.Request) {
  35. r.SetError(routerManager.InfusionContext(r)) //context注入全局信息
  36. r.Middleware.Next()
  37. })
  38. gateWayServer.Use(middleware.FilterHandler) //权限过滤
  39. //注册代理
  40. gateWayServer.BindHandler("POST:/*", proxyHandler) //接口代理
  41. gateWayServer.BindHandler("GET:/*", proxyHandler) //页面代理
  42. gateWayServer.AddStaticPath("/antiRes", "./resources/antiRes") //静态资源
  43. return gateWayServer
  44. }
  45. // proxyHandler 网关代理Handler处理
  46. // 完成所有前置校验后,请求代理服务逻辑
  47. var proxyHandler = func(r *ghttp.Request) {
  48. _, span := gtrace.NewSpan(r.Context(), "proxyHandler")
  49. defer span.End()
  50. if r.GetError() != nil {
  51. return
  52. }
  53. // 获取请求上下文内容
  54. gCtx := router.GetGContext(r.GetCtx())
  55. // 请求重试,防止某个服务中断不可用,导致接口不可用。
  56. for i := 0; i < errTryTime; i++ {
  57. // 代理地址存入上下文ctx中
  58. serverUrl, _ := url.Parse(gCtx.RouterRule.Server)
  59. gCtx.ServerAddr = serverUrl.String()
  60. router.UpdateGContext(r, gCtx)
  61. // 捕获异常,若代理出错,则进行重试
  62. var hasErr bool
  63. errHandel := func(hw http.ResponseWriter, hr *http.Request, err error) {
  64. hasErr = true
  65. if err.Error() == "context canceled" {
  66. return
  67. }
  68. if i == (errTryTime - 1) {
  69. r.SetError(NewErrorWithCode(GATEWAY_PROXY_ERR, fmt.Sprintf("代理异常:%s err:%v \n", gCtx.ServerAddr, err.Error())))
  70. }
  71. log.WithContext(r.Context()).Error("ErrorHandler ", err)
  72. }
  73. // 代理请求
  74. proxyClient.CreateCustomProxyClient(serverUrl, errHandel, nil).ServeHTTP(r.Response.ResponseWriter, r.Request)
  75. // 未捕获到请求,标识请求成功
  76. if !hasErr {
  77. return
  78. }
  79. }
  80. }