使用neo4j-jdbc open-connection是瓶颈

时间:2016-02-17 09:54:26

标签: java jdbc neo4j connection-pooling spring-data-neo4j

我正在使用neo4-jdbc和pool lib BasicDataSource。

我遇到了很大的延迟问题,所以我们分析了应用程序,我们发现开放连接是原因。我不明白为什么开放连接需要这么长时间我们使用池。这是我们的个人资料的截图:

enter image description here

这就是Neo4jDatasourceRemote的样子:

package com.comp.wm.common.repo;

import com.comp.wm.common.utils.Constants;
import org.apache.commons.dbcp.BasicDataSource;
import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Value;

import javax.annotation.PostConstruct;
import java.sql.Connection;
import java.sql.SQLException;




    private final Logger logger = Logger.getLogger(Neo4jDataSourceRemote.class);

    private BasicDataSource ds;

    @Value("${neo4j.host:localhost}")
    private String NEO4J_HOST;

    @Value("${neo4j.port:7474}")
    private String NEO4J_PORT;

    @Value("${neo4j.username:nouser}")
    private String NEO4J_USERNAME;

    @Value("${neo4j.password:nopass}")
    private String NEO4J_PASSWORD;

    @Value("${neo4j.pool.size:200}")
    private int NEO4J_POOL_SIZE;

    private String GetUrl() {
        return String.format(Constants.NEO4J_JDBC_CONNECTIVITY_STRING, NEO4J_HOST, NEO4J_PORT);
    }


    @PostConstruct
    public void init(){
        ds = new BasicDataSource();
        ds.setInitialSize(300);
        ds.setDriverClassName("org.neo4j.jdbc.Driver");
        ds.setUrl(GetUrl());
        ds.setUsername(NEO4J_USERNAME);
        ds.setPassword(NEO4J_PASSWORD);
    }


    @Override
    public Connection openConnection() throws SQLException {
        return this.ds.getConnection();
    }

    @Override
    public void closeConnection(Connection conn) {
        try {
            if (conn != null)
                conn.close();
        } catch (SQLException ex) {
            logger.info("error closing connection", ex);
        }
    }
}

这是我如何对图执行查询的示例:

public List<NearbyItem> executeQuery(..) {
        conn = neo4jDataSource.openConnection();


        String getUsersStatement = "some query..";

        try (PreparedStatement ps = conn.prepareStatement(getUsersStatement)) {
           ..
            ResultSet rs = ps.executeQuery();
            while (rs.next()) {
               ...
            }
        } catch (Exception e) {
            throw new RuntimeException("Error returning userId=" + userIdInput, e);
        } finally {
            neo4jDataSource.closeConnection(conn);
        }
        return distItemDatas;
    }

任何想法?

1 个答案:

答案 0 :(得分:0)

根据上述评论,我会将其添加为回复。

默认情况下,Neo4j在http接口上运行10个核心线程。您可以调整neo4j-server.properties

中的总线程数
org.neo4j.server.webserver.maxthreads=200

但是,您拥有的线程越多,您就越会受到上下文切换和锁争用的影响。如果你增加了我不会期望大幅增加吞吐量的线程数,你只需要转移你必须等待的点。从初始化(openCOnnection)到处理查询。