Java tutorial
/* * Copyright (c) 2016 The Ontario Institute for Cancer Research. All rights reserved. * * This program and the accompanying materials are made available under the terms of the GNU Public License v3.0. * You should have received a copy of the GNU General Public License along with * this program. If not, see <http://www.gnu.org/licenses/>. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT * SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package org.icgc.dcc.download.server.config; import java.util.Map; import java.util.concurrent.CompletionService; import java.util.concurrent.ExecutorCompletionService; import java.util.concurrent.Executors; import java.util.concurrent.Future; import lombok.NonNull; import lombok.val; import org.apache.hadoop.fs.FileSystem; import org.apache.spark.api.java.JavaSparkContext; import org.icgc.dcc.download.job.core.DefaultDownloadJob; import org.icgc.dcc.download.server.config.Properties.JobProperties; import org.icgc.dcc.download.server.repository.JobRepository; import org.icgc.dcc.download.server.service.DownloadService; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import com.google.common.collect.Maps; @Configuration public class CompletionServiceConfig { // TODO: Externalize private static final int THREADS_NUM = 2; @Bean public CompletionService<String> completionService() { val executor = Executors.newFixedThreadPool(THREADS_NUM); return new ExecutorCompletionService<String>(executor); } @Bean public Map<String, Future<String>> submittedJobs() { return Maps.newConcurrentMap(); } @Bean public DownloadService downloadService(@NonNull JavaSparkContext sparkContext, @NonNull FileSystem fileSystem, @NonNull JobProperties jobProperties, @NonNull JobRepository repository) { return new DownloadService(sparkContext, fileSystem, jobProperties, completionService(), repository, submittedJobs(), new DefaultDownloadJob()); } }