當前位置: 首頁>>代碼示例>>Java>>正文


Java HystrixCommand.Setter方法代碼示例

本文整理匯總了Java中com.netflix.hystrix.HystrixCommand.Setter方法的典型用法代碼示例。如果您正苦於以下問題:Java HystrixCommand.Setter方法的具體用法?Java HystrixCommand.Setter怎麽用?Java HystrixCommand.Setter使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.netflix.hystrix.HystrixCommand的用法示例。


在下文中一共展示了HystrixCommand.Setter方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: bottle

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
/**
 * [SLEUTH] TraceCommand
 */
@Override
public void bottle(Wort wort, String processId, String testCommunicationType) {
    log.info("I'm in the bottling service");
    log.info("Process ID from headers {}", processId);
    String groupKey = "bottling";
    String commandKey = "bottle";
    HystrixCommand.Setter setter = HystrixCommand.Setter
            .withGroupKey(HystrixCommandGroupKey.Factory.asKey(groupKey))
            .andCommandKey(HystrixCommandKey.Factory.asKey(commandKey));
    TestConfigurationHolder testConfigurationHolder = TestConfigurationHolder.TEST_CONFIG.get();
    new TraceCommand<Void>(tracer, traceKeys, setter) {
        @Override
        public Void doRun() throws Exception {
            TestConfigurationHolder.TEST_CONFIG.set(testConfigurationHolder);
            log.info("Sending info to bottling service about process id [{}]", processId);
            bottlerService.bottle(wort, processId);
            return null;
        }
    }.execute();
}
 
開發者ID:spring-cloud-samples,項目名稱:brewery,代碼行數:24,代碼來源:Bottler.java

示例2: commandKeyIsRequestLineSetterFactory

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Bean
public SetterFactory commandKeyIsRequestLineSetterFactory() {
	return new SetterFactory() {
		@Override public HystrixCommand.Setter create(Target<?> target,
			Method method) {
			String groupKey = SETTER_PREFIX + target.name();
			RequestMapping requestMapping = method
				.getAnnotation(RequestMapping.class);
			String commandKey =
				SETTER_PREFIX + requestMapping.method()[0] + " " + requestMapping
					.path()[0];
			return HystrixCommand.Setter
				.withGroupKey(HystrixCommandGroupKey.Factory.asKey(groupKey))
				.andCommandKey(HystrixCommandKey.Factory.asKey(commandKey));
		}
	};
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-netflix,代碼行數:18,代碼來源:FeignClientTests.java

示例3: create

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Override
public HystrixCommand.Setter create(Target<?> target, Method method) {
  String groupKey = target.name();
  String commandKey = Feign.configKey(target.type(), method);
  return HystrixCommand.Setter
      .withGroupKey(HystrixCommandGroupKey.Factory.asKey(groupKey))
      .andCommandKey(HystrixCommandKey.Factory.asKey(commandKey));
}
 
開發者ID:wenwu315,項目名稱:XXXX,代碼行數:9,代碼來源:SetterFactory.java

示例4: should_pass_tracing_information_when_using_Hystrix_commands

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Test
public void should_pass_tracing_information_when_using_Hystrix_commands() {
	Tracer tracer = new DefaultTracer(new AlwaysSampler(), new Random(),
			new DefaultSpanNamer(), new NoOpSpanLogger(), new NoOpSpanReporter());
	TraceKeys traceKeys = new TraceKeys();
	HystrixCommand.Setter setter = HystrixCommand.Setter
			.withGroupKey(HystrixCommandGroupKey.Factory.asKey("group"))
			.andCommandKey(HystrixCommandKey.Factory.asKey("command"));
	// tag::hystrix_command[]
	HystrixCommand<String> hystrixCommand = new HystrixCommand<String>(setter) {
		@Override
		protected String run() throws Exception {
			return someLogic();
		}
	};
	// end::hystrix_command[]
	// tag::trace_hystrix_command[]
	TraceCommand<String> traceCommand = new TraceCommand<String>(tracer, traceKeys, setter) {
		@Override
		public String doRun() throws Exception {
			return someLogic();
		}
	};
	// end::trace_hystrix_command[]

	String resultFromHystrixCommand = hystrixCommand.execute();
	String resultFromTraceCommand = traceCommand.execute();

	then(resultFromHystrixCommand).isEqualTo(resultFromTraceCommand);
	then(tracer.getCurrentSpan()).isNull();
}
 
開發者ID:reshmik,項目名稱:Zipkin,代碼行數:32,代碼來源:TraceCommandTests.java

示例5: HystrixProcessor

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
public HystrixProcessor(HystrixCommandGroupKey groupKey, HystrixCommandKey commandKey, HystrixCommandKey fallbackCommandKey,
                        HystrixCommand.Setter setter, HystrixCommand.Setter fallbackSetter,
                        Processor processor, Processor fallback, boolean fallbackViaNetwork) {
    this.groupKey = groupKey;
    this.commandKey = commandKey;
    this.fallbackCommandKey = fallbackCommandKey;
    this.setter = setter;
    this.fallbackSetter = fallbackSetter;
    this.processor = processor;
    this.fallback = fallback;
    this.fallbackViaNetwork = fallbackViaNetwork;
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:13,代碼來源:HystrixProcessor.java

示例6: shouldBuildHystrixCommandKeysUsingMethodMetadata

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Test
public void shouldBuildHystrixCommandKeysUsingMethodMetadata() throws Exception {
	factory = new HystrixCommandMetadataFactory(new SimpleEndpointMethod(MyApiWithCircuitBreaker.class.getMethod("simple")));

	HystrixCommand.Setter hystrixMetadata = factory.create();

	EmptyHystrixCommand command = new EmptyHystrixCommand(hystrixMetadata);

	assertEquals("MyApiWithCircuitBreaker", command.getCommandGroup().name());
	assertEquals("MyApiWithCircuitBreaker.simple", command.getCommandKey().name());
	assertEquals("MyApiWithCircuitBreaker", command.getThreadPoolKey().name());
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:13,代碼來源:HystrixCommandMetadataFactoryTest.java

示例7: HystrixCircuitBreakerEndpointCallExecutable

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
public HystrixCircuitBreakerEndpointCallExecutable(HystrixCommand.Setter hystrixMetadata, EndpointMethod endpointMethod,
		EndpointCallExecutable<T, R> delegate, Object fallback) {

	this.hystrixMetadata = hystrixMetadata;
	this.endpointMethod = endpointMethod;
	this.delegate = delegate;
	this.fallback = fallback;
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:9,代碼來源:HystrixCircuitBreakerEndpointCallExecutable.java

示例8: shouldBuildHystrixCommandKeysUsingMethodAnnotation

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Test
public void shouldBuildHystrixCommandKeysUsingMethodAnnotation() throws Exception {
	factory = new HystrixCommandMetadataFactory(new SimpleEndpointMethod(MyApiWithCircuitBreaker.class.getMethod("customizedKeys")));

	HystrixCommand.Setter hystrixMetadata = factory.create();

	EmptyHystrixCommand command = new EmptyHystrixCommand(hystrixMetadata);

	assertEquals("myGroupKey", command.getCommandGroup().name());
	assertEquals("myTestCommandKey", command.getCommandKey().name());
	assertEquals("myTestThreadPoolKey", command.getThreadPoolKey().name());
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:13,代碼來源:HystrixCommandMetadataFactoryTest.java

示例9: shouldBuildHystrixCommandPropertiesUsingMethodAnnotation

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Test
public void shouldBuildHystrixCommandPropertiesUsingMethodAnnotation() throws Exception {
	factory = new HystrixCommandMetadataFactory(new SimpleEndpointMethod(MyApiWithCircuitBreaker.class.getMethod("customizedProperties")));

	HystrixCommand.Setter hystrixMetadata = factory.create();

	EmptyHystrixCommand command = new EmptyHystrixCommand(hystrixMetadata);

	assertEquals("MyApiWithCircuitBreaker", command.getCommandGroup().name());
	assertEquals("MyApiWithCircuitBreaker.customizedProperties", command.getCommandKey().name());
	assertEquals("MyApiWithCircuitBreaker", command.getThreadPoolKey().name());

	assertEquals(ExecutionIsolationStrategy.SEMAPHORE, command.getProperties().executionIsolationStrategy().get());
	assertEquals(Integer.valueOf(2500), command.getProperties().executionTimeoutInMilliseconds().get());
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:16,代碼來源:HystrixCommandMetadataFactoryTest.java

示例10: create

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
public HystrixCommand.Setter create() {
	HystrixCommand.Setter setter = HystrixCommand.Setter
			.withGroupKey(groupKey())
				.andCommandKey(commandKey())
					.andThreadPoolKey(threadPoolKey())
						.andCommandPropertiesDefaults(commandProperties())
							.andThreadPoolPropertiesDefaults(threadPoolProperties());

	return setter;
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:11,代碼來源:HystrixCommandMetadataFactory.java

示例11: should_pass_tracing_information_when_using_Hystrix_commands

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
@Test
public void should_pass_tracing_information_when_using_Hystrix_commands() {
	Tracer tracer = new DefaultTracer(new AlwaysSampler(), new Random(),
			new DefaultSpanNamer(), new NoOpSpanLogger(), new NoOpSpanReporter(), new TraceKeys());
	TraceKeys traceKeys = new TraceKeys();
	HystrixCommand.Setter setter = withGroupKey(asKey("group"))
			.andCommandKey(HystrixCommandKey.Factory.asKey("command"));
	// tag::hystrix_command[]
	HystrixCommand<String> hystrixCommand = new HystrixCommand<String>(setter) {
		@Override
		protected String run() throws Exception {
			return someLogic();
		}
	};
	// end::hystrix_command[]
	// tag::trace_hystrix_command[]
	TraceCommand<String> traceCommand = new TraceCommand<String>(tracer, traceKeys, setter) {
		@Override
		public String doRun() throws Exception {
			return someLogic();
		}
	};
	// end::trace_hystrix_command[]

	String resultFromHystrixCommand = hystrixCommand.execute();
	String resultFromTraceCommand = traceCommand.execute();

	then(resultFromHystrixCommand).isEqualTo(resultFromTraceCommand);
	then(tracer.getCurrentSpan()).isNull();
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-sleuth,代碼行數:31,代碼來源:TraceCommandTests.java

示例12: Setter

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
public static HystrixCommand.Setter Setter(Class x, String groupName) {
    HystrixConfiguration config = configs.get(x);
    if (config == null) {
        config = new HystrixConfiguration(x);
        configs.put(x, config);
    }
    return config.setter(x, groupName);
}
 
開發者ID:jewzaam,項目名稱:hystrixexample,代碼行數:9,代碼來源:HystrixConfiguration.java

示例13: setter

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
private HystrixCommand.Setter setter(Class clazz, String groupName) {
    String name = clazz.getSimpleName() + ":" + groupName;
    return HystrixCommand.Setter.withGroupKey(HystrixCommandGroupKey.Factory.asKey(name))
            .andCommandKey(HystrixCommandKey.Factory.asKey(name))
            .andThreadPoolKey(HystrixThreadPoolKey.Factory.asKey(name))
            .andCommandPropertiesDefaults(HystrixCommandProperties.Setter()
                    .withExecutionIsolationStrategy(HystrixCommandProperties.ExecutionIsolationStrategy.valueOf(executionIsolationStrategy.get()))
                    .withExecutionIsolationSemaphoreMaxConcurrentRequests(executionIsolationSemaphoreMaxConcurrentRequests.get())
                    .withExecutionIsolationThreadInterruptOnTimeout(executionIsolationThreadInterruptOnTimeout.get())
                    .withExecutionIsolationThreadTimeoutInMilliseconds(executionIsolationThreadTimeoutInMilliseconds.get())
                    .withFallbackIsolationSemaphoreMaxConcurrentRequests(fallbackIsolationSemaphoreMaxConcurrentRequests.get())
            );
}
 
開發者ID:jewzaam,項目名稱:hystrixexample,代碼行數:14,代碼來源:HystrixConfiguration.java

示例14: getHystrixCommandSetter

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
public HystrixCommand.Setter getHystrixCommandSetter() {
  return HystrixCommand.Setter
      .withGroupKey(HystrixCommandGroupKey.Factory.asKey(hystrixCommandGroupKey))
      .andCommandPropertiesDefaults(getHystrixCommandProperties())
      .andThreadPoolPropertiesDefaults(threadpool.getHystrixThreadPoolPropertiesSetter());
}
 
開發者ID:dehora,項目名稱:outland,代碼行數:7,代碼來源:HystrixConfiguration.java

示例15: BaseHystrixCommandEndpointCallExecutableFactory

import com.netflix.hystrix.HystrixCommand; //導入方法依賴的package包/類
protected BaseHystrixCommandEndpointCallExecutableFactory(HystrixCommand.Setter hystrixMetadata) {
	this(hystrixMetadata, null);
}
 
開發者ID:ljtfreitas,項目名稱:java-restify,代碼行數:4,代碼來源:BaseHystrixCommandEndpointCallExecutableFactory.java


注:本文中的com.netflix.hystrix.HystrixCommand.Setter方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。