All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.tencent.polaris.plugin.lossless.common.LosslessRuleDictionary Maven / Gradle / Ivy

/*
 * Tencent is pleased to support the open source community by making polaris-java available.
 *
 * Copyright (C) 2021 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 com.tencent.polaris.plugin.lossless.common;

import java.util.List;
import java.util.Map;
import java.util.concurrent.TimeUnit;

import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
import com.tencent.polaris.api.pojo.InstanceWeight;
import com.tencent.polaris.api.pojo.ServiceKey;
import com.tencent.polaris.api.utils.CollectionUtils;
import com.tencent.polaris.specification.api.v1.traffic.manage.LosslessProto;

/**
 * Cache for lossless.
 * @author Shedfree Wu
 */
public class LosslessRuleDictionary {

	// cache for mapping between metadata and LosslessRule. {metadataKey: {metadataValue: LosslessRule}}
	private final Cache>> metadataLosslessRuleCache =
			CacheBuilder.newBuilder().build();

	private final Cache> instanceWeightCache = CacheBuilder.newBuilder().
			maximumSize(500).expireAfterWrite(5, TimeUnit.SECONDS).build();


	public Map> getMetadataLosslessRules(ServiceKey serviceKey) {
		return metadataLosslessRuleCache.getIfPresent(serviceKey);
	}

	public Map getInstanceWeight(ServiceKey serviceKey) {
		return instanceWeightCache.getIfPresent(serviceKey);
	}

	public void clearRules(ServiceKey serviceKey) {
		metadataLosslessRuleCache.invalidate(serviceKey);
		instanceWeightCache.invalidate(serviceKey);
	}

	public void putMetadataLosslessRules(ServiceKey serviceKey, List losslessRuleList)  {
		if (CollectionUtils.isEmpty(losslessRuleList)) {
			metadataLosslessRuleCache.invalidate(serviceKey);
			return;
		}
		Map> metadataLosslessRules =
				LosslessUtils.parseMetadataLosslessRules(losslessRuleList);
		metadataLosslessRuleCache.put(serviceKey, metadataLosslessRules);
	}

	public void putInstanceWeight(ServiceKey serviceKey, Map instanceWeight) {
		instanceWeightCache.put(serviceKey, instanceWeight);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy