NIFI-12633 Avoid resetting state in GetSolr on restart

This closes #8267

Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
Robert 2024-01-18 20:32:32 +01:00 committed by exceptionfactory
parent a95f327b31
commit 043e2dd3ff
No known key found for this signature in database
1 changed files with 8 additions and 1 deletions

View File

@ -41,6 +41,7 @@ import org.apache.nifi.annotation.behavior.Stateful;
import org.apache.nifi.annotation.configuration.DefaultSchedule; import org.apache.nifi.annotation.configuration.DefaultSchedule;
import org.apache.nifi.annotation.documentation.CapabilityDescription; import org.apache.nifi.annotation.documentation.CapabilityDescription;
import org.apache.nifi.annotation.documentation.Tags; import org.apache.nifi.annotation.documentation.Tags;
import org.apache.nifi.annotation.lifecycle.OnConfigurationRestored;
import org.apache.nifi.annotation.lifecycle.OnScheduled; import org.apache.nifi.annotation.lifecycle.OnScheduled;
import org.apache.nifi.components.AllowableValue; import org.apache.nifi.components.AllowableValue;
import org.apache.nifi.components.PropertyDescriptor; import org.apache.nifi.components.PropertyDescriptor;
@ -154,6 +155,7 @@ public class GetSolr extends SolrProcessor {
private static final DateTimeFormatter DATE_TIME_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", Locale.US); private static final DateTimeFormatter DATE_TIME_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", Locale.US);
private final AtomicBoolean configurationRestored = new AtomicBoolean(false);
private final AtomicBoolean clearState = new AtomicBoolean(false); private final AtomicBoolean clearState = new AtomicBoolean(false);
private final AtomicBoolean dateFieldNotInSpecifiedFieldsList = new AtomicBoolean(false); private final AtomicBoolean dateFieldNotInSpecifiedFieldsList = new AtomicBoolean(false);
private volatile String id_field = null; private volatile String id_field = null;
@ -211,10 +213,15 @@ public class GetSolr extends SolrProcessor {
@Override @Override
public void onPropertyModified(PropertyDescriptor descriptor, String oldValue, String newValue) { public void onPropertyModified(PropertyDescriptor descriptor, String oldValue, String newValue) {
if (propertyNamesForActivatingClearState.contains(descriptor.getName())) if (configurationRestored.get() && propertyNamesForActivatingClearState.contains(descriptor.getName()))
clearState.set(true); clearState.set(true);
} }
@OnConfigurationRestored
public void onConfigurationRestored() {
configurationRestored.set(true);
}
@OnScheduled @OnScheduled
public void clearState(final ProcessContext context) throws IOException { public void clearState(final ProcessContext context) throws IOException {
if (clearState.getAndSet(false)) if (clearState.getAndSet(false))