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

com.avanza.astrix.ft.hystrix.AstrixThreadPoolProperties Maven / Gradle / Ivy

/*
 * Copyright 2014 Avanza Bank AB
 *
 * 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 com.avanza.astrix.ft.hystrix;

import com.avanza.astrix.beans.config.BeanConfiguration;
import com.avanza.astrix.beans.core.AstrixBeanSettings;
import com.avanza.astrix.beans.core.AstrixBeanSettings.IntBeanSetting;
import com.avanza.astrix.config.DynamicIntProperty;
import com.netflix.hystrix.HystrixThreadPoolKey;
import com.netflix.hystrix.HystrixThreadPoolProperties;
import com.netflix.hystrix.strategy.properties.HystrixProperty;

class AstrixThreadPoolProperties extends HystrixThreadPoolProperties {
	
	static final IntBeanSetting MAX_QUEUE_SIZE = new IntBeanSetting("faultTolerance.queueSize", 1_000_000);
	private final BeanConfiguration beanConfiguration;

	AstrixThreadPoolProperties(BeanConfiguration beanConfiguration, HystrixThreadPoolKey key, HystrixThreadPoolProperties.Setter builder) {
		super(key, builder);
		this.beanConfiguration = beanConfiguration;
	}
	
	@Override
	public HystrixProperty queueSizeRejectionThreshold() {
		return new DynamicPropertyAdapter<>(beanConfiguration.get(AstrixBeanSettings.QUEUE_SIZE_REJECTION_THRESHOLD));
	}
	
	@Override
	public HystrixProperty coreSize() {
		return new DynamicPropertyAdapter<>(beanConfiguration.get(AstrixBeanSettings.CORE_SIZE));
	}
	
	@Override
	public HystrixProperty keepAliveTimeMinutes() {
		return new DynamicPropertyAdapter<>(new DynamicIntProperty(1)); 
	}
	
	@Override
	public HystrixProperty maxQueueSize() {
		return new DynamicPropertyAdapter<>(beanConfiguration.get(MAX_QUEUE_SIZE));
	}
	
	@Override
	public HystrixProperty metricsRollingStatisticalWindowBuckets() {
		return new DynamicPropertyAdapter<>(new DynamicIntProperty(10));
	}
	
	@Override
	public HystrixProperty metricsRollingStatisticalWindowInMilliseconds() {
		return new DynamicPropertyAdapter<>(new DynamicIntProperty(10_000)); 
	}
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy