core/stat/node_storage.go (52 lines of code) (raw):
// Copyright 1999-2020 Alibaba Group Holding Ltd.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// 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 stat
import (
"sync"
"github.com/alibaba/sentinel-golang/core/base"
"github.com/alibaba/sentinel-golang/logging"
)
type ResourceNodeMap map[string]*ResourceNode
var (
inboundNode = NewResourceNode(base.TotalInBoundResourceName, base.ResTypeCommon)
resNodeMap = make(ResourceNodeMap)
rnsMux = new(sync.RWMutex)
)
// InboundNode returns the global inbound statistic node.
func InboundNode() *ResourceNode {
return inboundNode
}
// ResourceNodeList returns the slice of all existing resource nodes.
func ResourceNodeList() []*ResourceNode {
rnsMux.RLock()
defer rnsMux.RUnlock()
list := make([]*ResourceNode, 0, len(resNodeMap))
for _, v := range resNodeMap {
list = append(list, v)
}
return list
}
func GetResourceNode(resource string) *ResourceNode {
rnsMux.RLock()
defer rnsMux.RUnlock()
return resNodeMap[resource]
}
func GetOrCreateResourceNode(resource string, resourceType base.ResourceType) *ResourceNode {
node := GetResourceNode(resource)
if node != nil {
return node
}
rnsMux.Lock()
defer rnsMux.Unlock()
node = resNodeMap[resource]
if node != nil {
return node
}
if len(resNodeMap) >= int(base.DefaultMaxResourceAmount) {
logging.Warn("[GetOrCreateResourceNode] Resource amount exceeds the threshold", "maxResourceAmount", base.DefaultMaxResourceAmount)
}
node = NewResourceNode(resource, resourceType)
resNodeMap[resource] = node
return node
}
func ResetResourceNodeMap() {
rnsMux.Lock()
defer rnsMux.Unlock()
resNodeMap = make(ResourceNodeMap)
}