本文整理汇总了Java中org.springframework.retry.policy.SimpleRetryPolicy类的典型用法代码示例。如果您正苦于以下问题:Java SimpleRetryPolicy类的具体用法?Java SimpleRetryPolicy怎么用?Java SimpleRetryPolicy使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
SimpleRetryPolicy类属于org.springframework.retry.policy包,在下文中一共展示了SimpleRetryPolicy类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: assertProcessEnded
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
private void assertProcessEnded(final ProcessInstance pi) {
// fetch active executions
RetryTemplate retryTemplate = new RetryTemplate();
final SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy();
retryPolicy.setMaxAttempts(5);
retryTemplate.setRetryPolicy(retryPolicy);
FixedBackOffPolicy backOffPolicy = new FixedBackOffPolicy();
retryTemplate.setBackOffPolicy(backOffPolicy);
retryTemplate.execute(new RetryCallback<Void, RuntimeException>() {
@Override
public Void doWithRetry(RetryContext retryContext) throws RuntimeException {
List<ProcessInstance> processInstances = runtimeService.createProcessInstanceQuery().list();
int processCount = processInstances.size();
LOGGER.info("waiting for process to end (Still {} process running).", processCount);
if (processCount > 0) {
for (ProcessInstance processInstance : processInstances) {
LOGGER.info("Process info: {} ", dumpprocessInstance(processInstance));
}
throw new IllegalStateException("Some process still running. Left :" + processCount);
}
return null;
}
});
}
示例2: retryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
/**
* Returns a retry template that always retries. Starts with a second interval between retries and doubles that interval up
* to a minute for each retry.
*
* @return A retry template.
*/
protected RetryTemplate retryTemplate() {
RetryTemplate retry = new RetryTemplate();
Map<Class<? extends Throwable>, Boolean> stopExceptions =
Collections.singletonMap(InterruptedException.class, Boolean.FALSE);
SimpleRetryPolicy retryPolicy =
new SimpleRetryPolicy(Integer.MAX_VALUE, stopExceptions, true, true);
retry.setRetryPolicy(retryPolicy);
ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
backOffPolicy.setInitialInterval(1000);
backOffPolicy.setMultiplier(2.0);
backOffPolicy.setMaxInterval(60000);
retry.setBackOffPolicy(backOffPolicy);
return retry;
}
示例3: arkClientRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Bean
public RetryTemplate arkClientRetryTemplate() {
RetryTemplate retryTemplate = new RetryTemplate();
Map<Class<? extends Throwable>, Boolean> includeExceptions = new HashMap<>();
includeExceptions.put(RuntimeException.class, true);
ExponentialBackOffPolicy exponentialBackOffPolicy = new ExponentialBackOffPolicy();
exponentialBackOffPolicy.setInitialInterval(10);
exponentialBackOffPolicy.setMultiplier(2.0);
retryTemplate.setBackOffPolicy(exponentialBackOffPolicy);
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy(10, includeExceptions);
retryPolicy.setMaxAttempts(10);
retryTemplate.setRetryPolicy(retryPolicy);
return retryTemplate;
}
示例4: arkClientRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Bean
public RetryTemplate arkClientRetryTemplate() {
RetryTemplate retryTemplate = new RetryTemplate();
Map<Class<? extends Throwable>, Boolean> includeExceptions = new HashMap<>();
includeExceptions.put(RuntimeException.class, true);
ExponentialBackOffPolicy exponentialBackOffPolicy = new ExponentialBackOffPolicy();
exponentialBackOffPolicy.setInitialInterval(100);
exponentialBackOffPolicy.setMultiplier(2.0);
retryTemplate.setBackOffPolicy(exponentialBackOffPolicy);
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy(5, includeExceptions);
retryPolicy.setMaxAttempts(5);
retryTemplate.setRetryPolicy(retryPolicy);
return retryTemplate;
}
示例5: createRetryPolicy
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
private static RetryPolicy createRetryPolicy() {
final SimpleRetryPolicy simpleRetryPolicy = new SimpleRetryPolicy();
simpleRetryPolicy.setMaxAttempts(5);
final Map<Class<? extends Throwable>, RetryPolicy> policyMap = new HashMap<>();
policyMap.put(TempoApiException.class, new NeverRetryPolicy());
policyMap.put(FeignException.class, new NeverRetryPolicy());
policyMap.put(IOException.class, simpleRetryPolicy);
policyMap.put(RetryableException.class, simpleRetryPolicy);
final ExceptionClassifierRetryPolicy retryPolicy = new ExceptionClassifierRetryPolicy();
retryPolicy.setPolicyMap(policyMap);
return simpleRetryPolicy;
}
示例6: afterPropertiesSet
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Override
public void afterPropertiesSet() throws Exception {
if (this.metadataRetryOperations == null) {
RetryTemplate retryTemplate = new RetryTemplate();
SimpleRetryPolicy simpleRetryPolicy = new SimpleRetryPolicy();
simpleRetryPolicy.setMaxAttempts(10);
retryTemplate.setRetryPolicy(simpleRetryPolicy);
ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
backOffPolicy.setInitialInterval(100);
backOffPolicy.setMultiplier(2);
backOffPolicy.setMaxInterval(1000);
retryTemplate.setBackOffPolicy(backOffPolicy);
this.metadataRetryOperations = retryTemplate;
}
}
示例7: getWithRetry
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
public ExitStatus getWithRetry(RetryCallback<ExitStatus, Exception> callback) {
RetryTemplate retryTemplate = new RetryTemplate();
FixedBackOffPolicy backOffPolicy = new FixedBackOffPolicy();
Map<Class<? extends Throwable>,Boolean> retryableExceptions = new HashMap<Class<? extends Throwable>,Boolean>();
retryableExceptions.put(ClientProtocolException.class, Boolean.TRUE);
retryableExceptions.put(IOException.class, Boolean.TRUE);
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy(retryAttempts, retryableExceptions);
backOffPolicy.setBackOffPeriod(backoffPeriod);
retryTemplate.setListeners(retryListeners);
retryTemplate.setBackOffPolicy(backOffPolicy);
retryTemplate.setRetryPolicy(retryPolicy);
try {
return retryTemplate.execute(callback);
} catch (Exception e) {
logger.error("Retry processing failed " + e.getMessage());
return ExitStatus.FAILED;
}
}
示例8: getRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
/**
* get a spring customized retry template
*
* @param retryAttempts
* @return a customized retry template
*/
private static RetryTemplate getRetryTemplate(int retryAttempts) {
// we set the retry time out
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy();
retryPolicy.setMaxAttempts(retryAttempts);
// our retry service
RetryTemplate retryTemplate = new RetryTemplate();
retryTemplate.setRetryPolicy(retryPolicy);
return retryTemplate;
}
示例9: fatalErrorOnlyLogs
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Test
public void fatalErrorOnlyLogs() {
ProjectRequest request = createProjectRequest();
this.retryTemplate.setRetryPolicy(new SimpleRetryPolicy(2,
Collections.singletonMap(Exception.class, true)));
mockServer.expect(requestTo("http://example.com/elastic/initializr/request"))
.andExpect(method(HttpMethod.POST))
.andRespond(withStatus(HttpStatus.INTERNAL_SERVER_ERROR));
mockServer.expect(requestTo("http://example.com/elastic/initializr/request"))
.andExpect(method(HttpMethod.POST))
.andRespond(withStatus(HttpStatus.INTERNAL_SERVER_ERROR));
this.statPublisher.handleEvent(new ProjectGeneratedEvent(request));
mockServer.verify();
}
示例10: execute
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Override
public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception {
RetryTemplate retryTemplate = new RetryTemplate();
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy();
retryPolicy.setMaxAttempts(3);
retryTemplate.setRetryPolicy(retryPolicy);
// HINT: 재시도 정책을 지정해서 3번까지 재시도를 수행합니다.
//
List<Discount> discounts = retryTemplate.execute(new RetryCallback<List<Discount>>() {
@Override
public List<Discount> doWithRetry(RetryContext context) throws Exception {
return discountService.getDiscounts();
}
});
discountsHolder.setDiscounts(discounts);
return RepeatStatus.FINISHED;
}
示例11: isResourcesReady
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
/**
* Ensures external dependencies are available before starting to read messages from the queue
* @return true if startup successful, false if not
*/
public boolean isResourcesReady() {
boolean isStartupOk = false;
ExponentialBackOffPolicy exponentialBackOffPolicy = getExponentialBackOffPolicy();
SimpleRetryPolicy retryPolicy = getSimpleRetryPolicy();
RetryTemplate retryTemplate = new RetryTemplate();
retryTemplate.setRetryPolicy(retryPolicy);
retryTemplate.setBackOffPolicy(exponentialBackOffPolicy);
retryTemplate.setThrowLastExceptionOnExhausted(true);
logger.info("Waiting for Author ELB to be in healthy state");
try {
isStartupOk = retryTemplate.execute(c -> {
boolean result = aemInstanceHelperService.isAuthorElbHealthy();
if(!result) //Needs to be healthy
throw new Exception("Author ELB does not appear to be in a healthy state");
return result;
});
} catch (Exception e) {
logger.error("Failed to receive healthy state from Author ELB", e);
}
return isStartupOk;
}
示例12: getRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Bean
protected RetryTemplate getRetryTemplate(@Value("${controller.retryCount:3}") int retryCount, @Value("${controller.intial_delay:1000}") int initialDelay, @Value("${controller.maxInterval:10000}") int maxInterval) {
RetryTemplate retryTemplate = new RetryTemplate();
retryTemplate.setRetryPolicy(new SimpleRetryPolicy(retryCount, Collections.singletonMap(RestClientException.class, true)));
ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
backOffPolicy.setInitialInterval(initialDelay);
backOffPolicy.setMaxInterval(maxInterval);
retryTemplate.setBackOffPolicy(backOffPolicy);
retryTemplate.setThrowLastExceptionOnExhausted(true);
retryTemplate.registerListener(new DefaultListenerSupport());
return retryTemplate;
}
示例13: createRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
private RetryTemplate createRetryTemplate(RabbitProperties.Retry properties) {
RetryTemplate template = new RetryTemplate();
SimpleRetryPolicy policy = new SimpleRetryPolicy();
policy.setMaxAttempts(properties.getMaxAttempts());
template.setRetryPolicy(policy);
ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
backOffPolicy.setInitialInterval(properties.getInitialInterval());
backOffPolicy.setMultiplier(properties.getMultiplier());
backOffPolicy.setMaxInterval(properties.getMaxInterval());
template.setBackOffPolicy(backOffPolicy);
return template;
}
开发者ID:vikrammane23,项目名称:https-github.com-g0t4-jenkins2-course-spring-boot,代码行数:13,代码来源:RabbitAutoConfiguration.java
示例14: sessionCouchbaseRetryTemplate
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Bean
@ConditionalOnMissingBean
public RetryTemplate sessionCouchbaseRetryTemplate(RetryLoggingListener listener) {
Map<Class<? extends Throwable>, Boolean> retryableExceptions = new HashMap<>(1);
retryableExceptions.put(Exception.class, true);
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy(sessionCouchbase.getPersistent().getRetry().getMaxAttempts(), retryableExceptions);
RetryTemplate retryTemplate = new RetryTemplate();
retryTemplate.setRetryPolicy(retryPolicy);
retryTemplate.registerListener(listener);
return retryTemplate;
}
示例15: retryOperations
import org.springframework.retry.policy.SimpleRetryPolicy; //导入依赖的package包/类
@Bean
public RetryOperations retryOperations() {
RetryTemplate retryTemplate = new RetryTemplate();
retryTemplate.setRetryPolicy(new SimpleRetryPolicy(3, Collections.<Class<? extends Throwable>, Boolean>singletonMap(RedisConnectionFailureException.class, true)));
ExponentialBackOffPolicy backOffPolicy = new ExponentialBackOffPolicy();
backOffPolicy.setInitialInterval(1000L);
backOffPolicy.setMaxInterval(1000L);
backOffPolicy.setMultiplier(2);
retryTemplate.setBackOffPolicy(backOffPolicy);
return retryTemplate;
}
开发者ID:spring-cloud,项目名称:spring-cloud-stream-app-starters,代码行数:12,代码来源:FieldValueCounterSinkStoreConfiguration.java