AWSNeptune连接池设置
创始人
2024-09-26 16:01:39
0

在使用AWS Neptune数据库时,我们可以使用以下代码示例来设置连接池:

import com.amazonaws.regions.Regions;
import com.amazonaws.services.neptune.AmazonNeptune;
import com.amazonaws.services.neptune.AmazonNeptuneClientBuilder;
import com.amazonaws.services.neptune.model.DBInstanceNotFoundException;

import java.util.Properties;

import org.apache.commons.dbcp2.BasicDataSource;

public class NeptuneConnectionPool {

    private BasicDataSource dataSource;

    public NeptuneConnectionPool(String endpoint, String port, String dbName, String username, String password, Regions region) throws Exception {
        dataSource = new BasicDataSource();

        dataSource.setUsername(username);
        dataSource.setPassword(password);
        dataSource.setUrl("jdbc:aws://" + endpoint + ":" + port + "/" + dbName + "?region=" + region.getName());
        dataSource.setDriverClassName("com.amazon.neptune.driver.GremlinDriver");

        // maximum number of active connections to allocate
        dataSource.setMaxTotal(20);

        // maximum number of connections to allow in the idle state
        dataSource.setMaxIdle(0);

        // minimum number of connections to allow in the idle state
        dataSource.setMinIdle(0);

        // maximum waiting time for an idle connection to become available
        dataSource.setMaxWaitMillis(10000);

        // validate connection before borrowing it from pool
        dataSource.setValidationQuery("SELECT 1");

        // check idle connection periodically
        dataSource.setTimeBetweenEvictionRunsMillis(60000);

        // validate idle connections during idle connection check
        dataSource.setTestWhileIdle(true);
    }

    public AmazonNeptune getConnection() throws DBInstanceNotFoundException {
        AmazonNeptune client = AmazonNeptuneClientBuilder.standard().withCredentials(new DefaultAWSCredentialsProviderChain()).build();
        client.describeDBInstances();
        client.shutdown();
        return client;
    }

    public BasicDataSource getDataSource() {
        return dataSource;
    }

    public void close() {
        try {
            dataSource.close();
        } catch (Exception e) {
        }
    }

}

其中,我们可以设置以下参数:

  • dataSource.setMaxTotal(20):连接池最大连接数
  • dataSource.setMaxIdle(0):最大空闲连接数
  • dataSource.setMinIdle(0):最小空闲连接数
  • `dataSource.setMaxWaitMillis(100

相关内容

热门资讯

这一现象值得深思!八闽辅助,H... 这一现象值得深思!八闽辅助,HH平台挂,阶段教程(新版有挂)-哔哩哔哩一、八闽辅助可以开透视的定义与...
透视计算!德普之星的辅助工具介... 透视计算!德普之星的辅助工具介绍,德普之星有辅助软件吗(透视)好像是真的挂(有挂秘诀)-哔哩哔哩1、...
此事引发广泛关注!新奇玩乐辅助... 此事引发广泛关注!新奇玩乐辅助器下载,哈糖大菠萝万能挂,法门教程(真的有挂)-哔哩哔哩1、用户打开应...
透视系统!德扑圈透视挂,德普软... 透视系统!德扑圈透视挂,德普软件(透视)原来存在有挂(真的有挂)-哔哩哔哩进入游戏-大厅左侧-新手福...
据悉!广东雀神智能插件,雀姬无... 据悉!广东雀神智能插件,雀姬无限钻石辅助,窍要教程(有人有挂)-哔哩哔哩;1、广东雀神智能插件模拟器...
透视存在!德普之星透视免费,德... 透视存在!德普之星透视免费,德普之星透视免费(透视)都是真的是有挂(有挂细节)-哔哩哔哩德普之星透视...
这一问题亟待解决!火神大厅科技... 这一问题亟待解决!火神大厅科技,新祥心辅助脚本,指南教程(有挂技巧)-哔哩哔哩1、完成新祥心辅助脚本...
透视挂透视!德普之星怎么设置埋... 透视挂透视!德普之星怎么设置埋牌,德普之星辅助工具如何设置(透视)竟然真的是有挂(有挂助手)-哔哩哔...
经核实!酷玩联盟破解版下载,聚... 经核实!酷玩联盟破解版下载,聚星ai辅助工具收费多少,窍要教程(有挂分析)-哔哩哔哩1、任何聚星ai...
透视能赢!德普之星透视软件免费... 透视能赢!德普之星透视软件免费入口官网,德普之星辅助工具如何设置(透视)果然存在有挂(有挂透视)-哔...