mirror of https://github.com/apache/nifi.git
NIFI-1493 This closes #211. removed Executor from InvokeScriptedProcessor
Signed-off-by: joewitt <joewitt@apache.org>
This commit is contained in:
parent
1c03fc7871
commit
8a05f6880a
|
@ -16,6 +16,19 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.script;
|
package org.apache.nifi.processors.script;
|
||||||
|
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
|
import javax.script.Invocable;
|
||||||
|
import javax.script.ScriptException;
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.nifi.annotation.behavior.DynamicProperty;
|
import org.apache.nifi.annotation.behavior.DynamicProperty;
|
||||||
|
@ -36,24 +49,6 @@ import org.apache.nifi.processor.ProcessorInitializationContext;
|
||||||
import org.apache.nifi.processor.Relationship;
|
import org.apache.nifi.processor.Relationship;
|
||||||
import org.apache.nifi.processor.exception.ProcessException;
|
import org.apache.nifi.processor.exception.ProcessException;
|
||||||
import org.apache.nifi.processor.util.StandardValidators;
|
import org.apache.nifi.processor.util.StandardValidators;
|
||||||
import org.apache.nifi.util.file.monitor.SynchronousFileWatcher;
|
|
||||||
|
|
||||||
import javax.script.Invocable;
|
|
||||||
import javax.script.ScriptException;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.concurrent.Executors;
|
|
||||||
import java.util.concurrent.ScheduledExecutorService;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
|
||||||
import java.util.concurrent.locks.Lock;
|
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
|
||||||
|
|
||||||
@Tags({"script", "invoke", "groovy", "python", "jython", "jruby", "ruby", "javascript", "js", "lua", "luaj"})
|
@Tags({"script", "invoke", "groovy", "python", "jython", "jruby", "ruby", "javascript", "js", "lua", "luaj"})
|
||||||
@CapabilityDescription("Experimental - Invokes a script engine for a Processor defined in the given script. The script must define "
|
@CapabilityDescription("Experimental - Invokes a script engine for a Processor defined in the given script. The script must define "
|
||||||
|
@ -70,66 +65,8 @@ public class InvokeScriptedProcessor extends AbstractScriptProcessor {
|
||||||
private final AtomicReference<Collection<ValidationResult>> validationResults =
|
private final AtomicReference<Collection<ValidationResult>> validationResults =
|
||||||
new AtomicReference<>((Collection<ValidationResult>) new ArrayList<ValidationResult>());
|
new AtomicReference<>((Collection<ValidationResult>) new ArrayList<ValidationResult>());
|
||||||
|
|
||||||
private final Lock lock = new ReentrantLock();
|
|
||||||
private SynchronousFileWatcher scriptWatcher;
|
|
||||||
|
|
||||||
private ScheduledExecutorService reloadService = null;
|
|
||||||
|
|
||||||
private AtomicBoolean scriptNeedsReload = new AtomicBoolean(true);
|
private AtomicBoolean scriptNeedsReload = new AtomicBoolean(true);
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the resources needed by this processor. An attempt is made to also initialize the scripted processor,
|
|
||||||
* but unless the properties (such as script engine name and script file path) have already been specified, the
|
|
||||||
* script will not yet have been evaluated, so the script's initialize() method will not be called.
|
|
||||||
*/
|
|
||||||
protected void createResources() {
|
|
||||||
|
|
||||||
// Set up script file reloader service. This checks to see if the script file has changed, and if so, tries
|
|
||||||
// to reload it
|
|
||||||
if (reloadService == null) {
|
|
||||||
reloadService = Executors.newScheduledThreadPool(1);
|
|
||||||
|
|
||||||
// monitor the script if configured for changes
|
|
||||||
reloadService.scheduleWithFixedDelay(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
try {
|
|
||||||
final boolean hasLock = lock.tryLock();
|
|
||||||
|
|
||||||
// if a property is changing we don't need to reload this iteration
|
|
||||||
if (hasLock) {
|
|
||||||
try {
|
|
||||||
if (scriptWatcher != null && scriptWatcher.checkAndReset()) {
|
|
||||||
if (isFile(scriptPath)) {
|
|
||||||
// reload the actual script
|
|
||||||
final boolean reloaded = reloadScriptFile(scriptPath);
|
|
||||||
|
|
||||||
// log the script was reloaded
|
|
||||||
if (reloaded) {
|
|
||||||
getLogger().info("The configured script has been successfully reloaded.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} finally {
|
|
||||||
lock.unlock();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (final Throwable t) {
|
|
||||||
final ProcessorLog logger = getLogger();
|
|
||||||
final String message = "Unable to reload configured script Processor: " + t;
|
|
||||||
|
|
||||||
logger.error(message);
|
|
||||||
if (logger.isDebugEnabled()) {
|
|
||||||
logger.error(message, t);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, 30, 10, TimeUnit.SECONDS);
|
|
||||||
}
|
|
||||||
|
|
||||||
super.createResources();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the valid relationships for this processor. SUCCESS and FAILURE are always returned, and if the script
|
* Returns the valid relationships for this processor. SUCCESS and FAILURE are always returned, and if the script
|
||||||
* processor has defined additional relationships, those will be added as well.
|
* processor has defined additional relationships, those will be added as well.
|
||||||
|
@ -516,7 +453,7 @@ public class InvokeScriptedProcessor extends AbstractScriptProcessor {
|
||||||
// Initialize the rest of the processor resources if we have not already done so
|
// Initialize the rest of the processor resources if we have not already done so
|
||||||
synchronized (isInitialized) {
|
synchronized (isInitialized) {
|
||||||
if (!isInitialized.get()) {
|
if (!isInitialized.get()) {
|
||||||
createResources();
|
super.createResources();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue