代码拉取完成,页面将自动刷新
/**
* 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
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。