javaneo4jneo4j-driver

Neo4J connection pool is closing after application starts


I'm running my application and Neo4j 4 in Docker compose environment. After starting my application I'm getting some weird logs that connection pool is closing connection to DB (Closing connection pool towards graphdb(172.21.0.4):7687) and after this neo4jClient is unable to query DB (logs below). What is the reason of this behaviour?

BTW. I created Spring Health Check (driver.verifyConnectivity()), but it always return OK (no error is thrown).

Any ideas?


@Configuration
class Neo4jConfiguration {
    private val logger = LoggerFactory.getLogger(Neo4jConfiguration::class.java)

    @Bean
    fun neo4jDriver(
            @Value("\${spring.data.neo4j.host}") host: String?,
            @Value("\${spring.data.neo4j.port}") port: Int?): Driver {
        val connectionUrl = "neo4j://$host:$port"
        logger.info("Connecting to Neo4j on `$connectionUrl`")
        return GraphDatabase.driver(connectionUrl/*, AuthTokens.basic("neo4j", "secret")*/) 
    }

    @Bean
    fun neo4jClient(): ReactiveNeo4jClient = ReactiveNeo4jClient.create(neo4jDriver(null, null))

    @Bean
    fun neo4jTransactionManager() = ReactiveNeo4jTransactionManager(neo4jDriver(null, null))
}

Docker compose:

version: '3.7'
services:
  graphdb:
    image: neo4j:4.0.0
    ports:
      - 7474:7474
      - 7687:7687
    environment:
      NEO4J_AUTH: none
      NEO4J_dbms_connectors_default__listen__address: 0.0.0.0
    volumes:
      - ./docker/neo4j/data:/data
    networks:
      - things
networks:
  things:
    name: things

Full logs:

2020-02-24 20:57:32.922  INFO 1 --- [  restartedMain] c.t.r.repo.neo4j.Neo4jConfiguration      : Connecting to Neo4j on `neo4j://graphdb:7687`
2020-02-24 20:57:33.321  INFO 1 --- [  restartedMain] Driver                                   : Routing driver instance 656417291 created for server address graphdb:7687
2020-02-24 20:57:43.329  INFO 1 --- [o4jDriverIO-2-3] LoadBalancer                             : Routing table for database 'system' is stale. Ttl 1582577863326, currentTime 1582577863328, routers AddressSet=[], writers AddressSet=[], readers AddressSet=[], database 'system'
2020-02-24 20:57:43.437  INFO 1 --- [o4jDriverIO-2-2] ConnectionPool                           : Closing connection pool towards graphdb(172.21.0.4):7687, it has no active connections and is not in the routing table registry.
2020-02-24 20:57:43.440  INFO 1 --- [o4jDriverIO-2-2] LoadBalancer                             : Updated routing table for database 'system'. Ttl 1582578163422, currentTime 1582577863439, routers AddressSet=[0.0.0.0:7687], writers AddressSet=[0.0.0.0:7687], readers AddressSet=[0.0.0.0:7687], database 'system'
2020-02-24 20:58:02.694  INFO 1 --- [ault-executor-1] LoadBalancer                             : Routing table for database '<default database>' is stale. Ttl 1582577882693, currentTime 1582577882694, routers AddressSet=[], writers AddressSet=[], readers AddressSet=[], database '<default database>'
2020-02-24 20:58:02.777  INFO 1 --- [o4jDriverIO-2-2] ConnectionPool                           : Closing connection pool towards graphdb(172.21.0.4):7687, it has no active connections and is not in the routing table registry.
2020-02-24 20:58:02.777  INFO 1 --- [o4jDriverIO-2-2] LoadBalancer                             : Updated routing table for database '<default database>'. Ttl 1582578182776, currentTime 1582577882777, routers AddressSet=[0.0.0.0:7687], writers AddressSet=[0.0.0.0:7687], readers AddressSet=[0.0.0.0:7687], database '<default database>'
2020-02-24 20:58:02.803  WARN 1 --- [o4jDriverIO-2-2] LoadBalancer                             : Failed to obtain a connection towards address 0.0.0.0:7687

org.neo4j.driver.exceptions.SessionExpiredException: Server at 0.0.0.0:7687 is no longer available
    at org.neo4j.driver.internal.cluster.loadbalancing.LoadBalancer.lambda$acquire$9(LoadBalancer.java:204) ~[neo4j-java-driver-4.0.0.jar:4.0.0-d03d93ede8ad65657eeb90ed890757203ecfaa7a]
    at java.base/java.util.concurrent.CompletableFuture.uniWhenComplete(Unknown Source) ~[na:na]
    at java.base/java.util.concurrent.CompletableFuture.uniWhenCompleteStage(Unknown Source) ~[na:na]
  [... removed ...]
Caused by: org.neo4j.driver.exceptions.ServiceUnavailableException: Unable to connect to 0.0.0.0:7687, ensure the database is running and that there is a working network connection to it.
    at org.neo4j.driver.internal.async.connection.ChannelConnectedListener.databaseUnavailableError(ChannelConnectedListener.java:76) ~[neo4j-java-driver-4.0.0.jar:4.0.0-d03d93ede8ad65657eeb90ed890757203ecfaa7a]
    at org.neo4j.driver.internal.async.connection.ChannelConnectedListener.operationComplete(ChannelConnectedListener.java:70) ~[neo4j-java-driver-4.0.0.jar:4.0.0-d03d93ede8ad65657eeb90ed890757203ecfaa7a]
    at org.neo4j.driver.internal.async.connection.ChannelConnectedListener.operationComplete(ChannelConnectedListener.java:37) ~[neo4j-java-driver-4.0.0.jar:4.0.0-d03d93ede8ad65657eeb90ed890757203ecfaa7a]
  [... removed ...]
    ... 7 common frames omitted
Caused by: org.neo4j.driver.internal.shaded.io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: /0.0.0.0:7687
Caused by: java.net.ConnectException: Connection refused
    at java.base/sun.nio.ch.SocketChannelImpl.checkConnect(Native Method) ~[na:na]
    at java.base/sun.nio.ch.SocketChannelImpl.finishConnect(Unknown Source) ~[na:na]
    [... removed ...]

Solution

  • I have just come across the same problem, after a little experimenting turns out that the ip should be "bolt://$host:$port" and not "neo4j://$host:$port"

    Seems like some of the spring.io tutorials are out of date.