1 Star 0 Fork 0

蒙蒙的男孩 / polaris-go

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
router_flow.go 3.15 KB
一键复制 编辑 原始数据 按行查看 历史
蒙蒙的男孩 提交于 2023-10-26 20:52 . 添加调用方的实例ip属性
/**
* Tencent is pleased to support the open source community by making polaris-go available.
*
* Copyright (C) 2019 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
package flow
import (
"gitee.com/meng_mengs_boys/polaris-go/pkg/config"
"gitee.com/meng_mengs_boys/polaris-go/pkg/flow/data"
"gitee.com/meng_mengs_boys/polaris-go/pkg/model"
"gitee.com/meng_mengs_boys/polaris-go/pkg/plugin/common"
"gitee.com/meng_mengs_boys/polaris-go/pkg/plugin/servicerouter"
)
// ProcessRouters 执行路由链过滤,返回经过路由后的实例列表
func (e *Engine) ProcessRouters(req *model.ProcessRoutersRequest) (*model.InstancesResponse, error) {
routers, err := e.parseRouters(req.Routers)
if nil != err {
return nil, err
}
commonRequest := data.PoolGetCommonInstancesRequest(e.plugins)
commonRequest.InitByProcessRoutersRequest(req, e.configuration, routers)
resp, err := e.doSyncGetInstances(commonRequest)
e.syncInstancesReportAndFinalize(commonRequest)
return resp, err
}
func (e *Engine) parseRouters(routers []string) ([]servicerouter.ServiceRouter, error) {
var svcRouters []servicerouter.ServiceRouter
if len(routers) == 0 {
return svcRouters, nil
}
// 如果最后一个路由规则不是 filterOnly 或者 zeroProtect 的话
lastRouter := routers[len(routers)-1]
if lastRouter != config.DefaultServiceRouterFilterOnly && lastRouter != config.DefaultServiceRouterZeroProtect {
afterChain := e.configuration.GetConsumer().GetServiceRouter().GetAfterChain()
lastRouterName := config.DefaultServiceRouterFilterOnly
for i := range afterChain {
if afterChain[i] == config.DefaultServiceRouterFilterOnly {
lastRouterName = config.DefaultServiceRouterFilterOnly
}
if afterChain[i] == config.DefaultServiceRouterZeroProtect {
lastRouterName = config.DefaultServiceRouterZeroProtect
}
}
routers = append(routers, lastRouterName)
}
for _, router := range routers {
targetPlugin, err := e.plugins.GetPlugin(common.TypeServiceRouter, router)
if err != nil {
return nil, err
}
svcRouters = append(svcRouters, targetPlugin.(servicerouter.ServiceRouter))
}
return svcRouters, nil
}
// ProcessLoadBalance 执行负载均衡策略,返回负载均衡后的实例
func (e *Engine) ProcessLoadBalance(req *model.ProcessLoadBalanceRequest) (*model.OneInstanceResponse, error) {
// 方法开始时间
commonRequest := data.PoolGetCommonInstancesRequest(e.plugins)
commonRequest.InitByProcessLoadBalanceRequest(req, e.configuration)
startTime := e.globalCtx.Now()
resp, err := e.doLoadBalanceToOneInstance(startTime, commonRequest)
e.syncInstancesReportAndFinalize(commonRequest)
return resp, err
}
1
https://gitee.com/meng_mengs_boys/polaris-go.git
git@gitee.com:meng_mengs_boys/polaris-go.git
meng_mengs_boys
polaris-go
polaris-go
v1.5.4

搜索帮助