Neo4j Connection

    They can also be managed with the metadata perspective in the Hop GUI.

    Neo4j Connections are serialized as JSON in the Hop metadata folder under

    The user interface

    In most cases the Neo4j can figure out the protocol and security options automatically allowing you to focus on the most elementary options: server, port, username and password. As per usual we recommend that you never hardcode any settings but use environment variables which you can define in an environment configuration file. This way the same Neo4j connection can be used in multiple environments without the need to change pipelines or workflows.

    The Protocol options

    To connect to an Aura version 4 database you can use the following options:

    The Advanced options

    Pooled connections that have been idle in the pool for longer than this timeout will be tested before they are used again, to ensure they are still live. If this option is set too low, an additional network call will be incurred when acquiring a connection, which causes a performance hit.

    If this is set high, you may receive sessions that are backed by no longer live connections, which will lead to exceptions in your application. Assuming the database is running, these exceptions will go away if you retry acquiring sessions.

    Hence, this parameter tunes a balance between the likelihood of your application seeing connection problems, and performance.

    You normally should not need to tune this parameter. No connection liveliness check is done by default. Value 0 means connections will always be tested for validity and negative values mean connections will never be tested.

    Maximum Connection Lifetime (ms)

    Pooled connections older than this threshold will be closed and removed from the pool. Such discarding happens during connection acquisition so that new session is never backed by an old connection. Setting this option to a low value will cause a high connection churn and might result in a performance hit.

    It is recommended to set maximum lifetime to a slightly smaller value than the one configured in network equipment (load balancer, proxy, firewall, etc. can also limit maximum connection lifetime).

    Setting can also be used in combination with the Connection Liveness Check Timeout (ms) value. In this case, it is recommended to set liveness check to a value smaller than network equipment has and maximum lifetime to a reasonably large value to “renew” connections once in a while.

    Default maximum connection lifetime is 1 hour. Zero and negative values result in lifetime not being checked.

    Configure the maximum amount of connections in the connection pool towards a single database. This setting limits total amount of connections in the pool when used in direct driver, created for URI with ‘bolt’ scheme. It will limit amount of connections per cluster member when used with routing driver, created for URI with ‘neo4j’ scheme.

    Acquisition will be attempted for at most configured timeout Connection Acquisition Timeout(ms) when limit is reached.

    Default value is 100. Negative values are allowed and result in unlimited pool. Value of 0 is not allowed.

    Connection Acquisition Time (ms)

    Configure the maximum amount of time the connection acquisition will attempt to acquire a connection from the connection pool. This timeout only kicks in when all existing connections are being used and no new connections can be created because maximum connection pool size has been reached. An error is thrown when a connection can’t be acquired within the configured time.

    The default value is 60 seconds. Negative values are allowed and result in unlimited acquisition timeout. Value of 0 is allowed and results in no timeout and immediate failure when connection is unavailable.

    Specify the maximum time transactions are allowed to retry via session read and write transactions. These methods will retry the given unit of work on ServiceUnavailableException, SessionExpiredException and TransientException with an exponential backoff using initial delay of 1 second. Default value is 30 seconds.

    Manual URLs

    You can specify a list of manual connection URLs to allow you to work with any advanced, legacy, bleeding edge, …​ feature you can possibly want. See here for more information on Bolt connection URIs: