mirror of https://github.com/apache/nifi.git
NIFI-868 Configure advertised host name of Remote Process Group Input Port
Before this change, the host given out to clients to connect to a Remote Process Group Input Port is the host where the NiFi instance runs. However, sometimes the binding host is different from the host that clients connect to. For example, when a NiFi instance runs inside a Docker container, a client on a separate machine must connect to the Docker host which forwards the connection to the container. Add a configuration property to specify the host name to give out to clients to connect to a Remote Process Group Input Port. If the property is not configured, then give out the name of host running the NiFi instance.
This commit is contained in:
parent
8e5347156f
commit
8f98f80938
|
@ -59,6 +59,7 @@ public class NiFiProperties extends Properties {
|
||||||
public static final String SENSITIVE_PROPS_ALGORITHM = "nifi.sensitive.props.algorithm";
|
public static final String SENSITIVE_PROPS_ALGORITHM = "nifi.sensitive.props.algorithm";
|
||||||
public static final String SENSITIVE_PROPS_PROVIDER = "nifi.sensitive.props.provider";
|
public static final String SENSITIVE_PROPS_PROVIDER = "nifi.sensitive.props.provider";
|
||||||
public static final String H2_URL_APPEND = "nifi.h2.url.append";
|
public static final String H2_URL_APPEND = "nifi.h2.url.append";
|
||||||
|
public static final String REMOTE_INPUT_HOST = "nifi.remote.input.socket.host";
|
||||||
public static final String REMOTE_INPUT_PORT = "nifi.remote.input.socket.port";
|
public static final String REMOTE_INPUT_PORT = "nifi.remote.input.socket.port";
|
||||||
public static final String SITE_TO_SITE_SECURE = "nifi.remote.input.secure";
|
public static final String SITE_TO_SITE_SECURE = "nifi.remote.input.secure";
|
||||||
public static final String TEMPLATE_DIRECTORY = "nifi.templates.directory";
|
public static final String TEMPLATE_DIRECTORY = "nifi.templates.directory";
|
||||||
|
@ -366,6 +367,16 @@ public class NiFiProperties extends Properties {
|
||||||
return getProperty(ADMINISTRATIVE_YIELD_DURATION, DEFAULT_ADMINISTRATIVE_YIELD_DURATION);
|
return getProperty(ADMINISTRATIVE_YIELD_DURATION, DEFAULT_ADMINISTRATIVE_YIELD_DURATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The host name that will be given out to clients to connect to the Remote Input Port.
|
||||||
|
*
|
||||||
|
* @return the remote input host name or null if not configured
|
||||||
|
*/
|
||||||
|
public String getRemoteInputHost() {
|
||||||
|
final String value = getProperty(REMOTE_INPUT_HOST);
|
||||||
|
return StringUtils.isBlank(value) ? null : value;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The socket port to listen on for a Remote Input Port.
|
* The socket port to listen on for a Remote Input Port.
|
||||||
*
|
*
|
||||||
|
|
|
@ -549,6 +549,7 @@ These properties govern how this instance of NiFi communicates with remote insta
|
||||||
|
|
||||||
|====
|
|====
|
||||||
|*Property*|*Description*
|
|*Property*|*Description*
|
||||||
|
|nifi.remote.input.socket.host|The host name that will be given out to clients to connect to this NiFi instance for Site-to-Site communication. By default, it is the value from InetAddress.getLocalHost().getHostName(). On UNIX-like operating systems, this is typically the output from the `hostname` command.
|
||||||
|nifi.remote.input.socket.port|The remote input socket port for Site-to-Site communication. By default, it is blank, but it must have a value in order to use Remote Process Groups.
|
|nifi.remote.input.socket.port|The remote input socket port for Site-to-Site communication. By default, it is blank, but it must have a value in order to use Remote Process Groups.
|
||||||
|nifi.remote.input.secure|This indicates whether communication between this instance of NiFi and remote NiFi instances should be secure. By default, it is set to _true_. In order for secure site-to-site to work, many Security Properties (below) must also be configured.
|
|nifi.remote.input.secure|This indicates whether communication between this instance of NiFi and remote NiFi instances should be secure. By default, it is set to _true_. In order for secure site-to-site to work, many Security Properties (below) must also be configured.
|
||||||
|====
|
|====
|
||||||
|
|
|
@ -95,6 +95,7 @@ nifi.components.status.repository.buffer.size=${nifi.components.status.repositor
|
||||||
nifi.components.status.snapshot.frequency=${nifi.components.status.snapshot.frequency}
|
nifi.components.status.snapshot.frequency=${nifi.components.status.snapshot.frequency}
|
||||||
|
|
||||||
# Site to Site properties
|
# Site to Site properties
|
||||||
|
nifi.remote.input.socket.host=
|
||||||
nifi.remote.input.socket.port=
|
nifi.remote.input.socket.port=
|
||||||
nifi.remote.input.secure=true
|
nifi.remote.input.secure=true
|
||||||
|
|
||||||
|
|
|
@ -612,9 +612,15 @@ public class SocketFlowFileServerProtocol implements ServerProtocol {
|
||||||
|
|
||||||
final NiFiProperties properties = NiFiProperties.getInstance();
|
final NiFiProperties properties = NiFiProperties.getInstance();
|
||||||
|
|
||||||
|
String remoteInputHost = properties.getRemoteInputHost();
|
||||||
|
if (remoteInputHost == null) {
|
||||||
|
remoteInputHost = InetAddress.getLocalHost().getHostName();
|
||||||
|
}
|
||||||
|
logger.debug("{} Advertising Remote Input host name {}", this, peer);
|
||||||
|
|
||||||
// we have only 1 peer: ourselves.
|
// we have only 1 peer: ourselves.
|
||||||
dos.writeInt(1);
|
dos.writeInt(1);
|
||||||
dos.writeUTF(InetAddress.getLocalHost().getHostName());
|
dos.writeUTF(remoteInputHost);
|
||||||
dos.writeInt(properties.getRemoteInputPort());
|
dos.writeInt(properties.getRemoteInputPort());
|
||||||
dos.writeBoolean(properties.isSiteToSiteSecure());
|
dos.writeBoolean(properties.isSiteToSiteSecure());
|
||||||
dos.writeInt(0); // doesn't matter how many FlowFiles we have, because we're the only host.
|
dos.writeInt(0); // doesn't matter how many FlowFiles we have, because we're the only host.
|
||||||
|
|
|
@ -67,6 +67,7 @@ nifi.components.status.snapshot.frequency=10 secs
|
||||||
|
|
||||||
# Site to Site properties
|
# Site to Site properties
|
||||||
#For testing purposes. Default value should actually be empty!
|
#For testing purposes. Default value should actually be empty!
|
||||||
|
nifi.remote.input.socket.host=
|
||||||
nifi.remote.input.socket.port=
|
nifi.remote.input.socket.port=
|
||||||
nifi.remote.input.secure=false
|
nifi.remote.input.secure=false
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue