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

com.amazonaws.services.kinesis.multilang.DrainChildSTDOUTTask Maven / Gradle / Ivy

Go to download

The Amazon Kinesis Client Library for Java enables Java developers to easily consume and process data from Amazon Kinesis.

There is a newer version: 1.15.2
Show newest version
/*
 * Copyright 2019 Amazon.com, Inc. or its affiliates.
 * 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.amazonaws.services.kinesis.multilang;

import java.io.BufferedReader;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * This class is used to drain the STDOUT of the child process. After the child process has been given a shutdown
 * message and responded indicating that it is shutdown, we attempt to close the input and outputs of that process so
 * that the process can exit.
 * 
 * To understand why this is necessary, consider the following scenario:
 * 
 * 
    *
  1. Child process responds that it is done with shutdown.
  2. *
  3. Child process prints debugging text to STDOUT that fills the pipe buffer so child becomes blocked.
  4. *
  5. Parent process doesn't drain child process's STDOUT.
  6. *
  7. Child process remains blocked.
  8. *
* * To prevent the child process from becoming blocked in this way, it is the responsibility of the parent process to * drain the child process's STDOUT. We reprint each drained line to our log to permit debugging. */ class DrainChildSTDOUTTask extends LineReaderTask { private static final Log LOG = LogFactory.getLog(DrainChildSTDOUTTask.class); DrainChildSTDOUTTask() { } @Override protected HandleLineResult handleLine(String line) { LOG.info("Drained line for shard " + getShardId() + ": " + line); return new HandleLineResult(); } @Override protected Boolean returnAfterException(Exception e) { LOG.info("Encountered exception while draining STDOUT of child process for shard " + getShardId(), e); return false; } @Override protected Boolean returnAfterEndOfInput() { return true; } public LineReaderTask initialize(BufferedReader reader, String shardId) { return initialize(reader, shardId, "Draining STDOUT for " + shardId); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy