Skip to content

Commit

Permalink
retry for scopus with fibonacci seq with multipler of 100 and upto 2 min
Browse files Browse the repository at this point in the history
  • Loading branch information
sarbajitdutta committed Apr 1, 2019
1 parent a02a1f4 commit a4952a2
Showing 1 changed file with 26 additions and 4 deletions.
30 changes: 26 additions & 4 deletions src/main/java/reciter/scopus/retriever/ScopusArticleRetriever.java
Original file line number Diff line number Diff line change
@@ -1,15 +1,23 @@
package reciter.scopus.retriever;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.github.rholder.retry.Retryer;
import com.github.rholder.retry.Retryer.RetryerCallable;
import com.github.rholder.retry.RetryerBuilder;
import com.github.rholder.retry.StopStrategies;
import com.github.rholder.retry.WaitStrategies;
import com.google.common.base.Predicates;

import reciter.model.scopus.ScopusArticle;
import reciter.scopus.callable.ScopusUriParserCallable;
import reciter.scopus.querybuilder.ScopusXmlQuery;
Expand All @@ -29,6 +37,11 @@ public class ScopusArticleRetriever {
*/
protected static final int SCOPUS_MAX_THRESHOLD = 25;

/**
* @param pmids scopus query could be DOI, scopusDocId, PMID
* @param type to query scopus like DOI(), SCOPUS-ID(), PMID() etc.
* @return
*/
public List<ScopusArticle> retrieveScopus(List<Object> pmids, String type) {
slf4jLogger.info("Pmids:" + pmids);
List<String> pmidQueries = new ArrayList<>();
Expand Down Expand Up @@ -62,16 +75,25 @@ public List<ScopusArticle> retrieveScopus(List<Object> pmids, String type) {
}
}

List<Callable<List<ScopusArticle>>> callables = new ArrayList<>();
List<RetryerCallable<List<ScopusArticle>>> callables = new ArrayList<RetryerCallable<List<ScopusArticle>>>();
Retryer<List<ScopusArticle>> retryer = RetryerBuilder.<List<ScopusArticle>>newBuilder()
.retryIfResult(Predicates.<List<ScopusArticle>>isNull())
.retryIfExceptionOfType(IOException.class)
.retryIfRuntimeException()
.withWaitStrategy(WaitStrategies.fibonacciWait(100L, 2L, TimeUnit.MINUTES))
.withStopStrategy(StopStrategies.stopAfterAttempt(10))
.build();

for (String query : pmidQueries) {
ScopusXmlQuery scopusXmlQuery = new ScopusXmlQuery.ScopusXmlQueryBuilder(query, SCOPUS_MAX_THRESHOLD).build();
String scopusUrl = scopusXmlQuery.getQueryUrl();
ScopusUriParserCallable scopusUriParserCallable = new ScopusUriParserCallable(new ScopusXmlHandler(), scopusUrl);
callables.add(scopusUriParserCallable);
RetryerCallable<List<ScopusArticle>> retryerCallable = retryer.wrap(scopusUriParserCallable);
callables.add(retryerCallable);
//callables.add(scopusUriParserCallable);
}

List<List<ScopusArticle>> list = new ArrayList<>();
List<List<ScopusArticle>> list = new ArrayList<List<ScopusArticle>>();

int numAvailableProcessors = Runtime.getRuntime().availableProcessors();
ExecutorService executor = Executors.newFixedThreadPool(numAvailableProcessors);
Expand Down

0 comments on commit a4952a2

Please sign in to comment.