[英]How to use CopyManager with connection pooled DataSource?
我正在尝试将postgres
CopyManager.copyIn()
用于批处理插入。 我的数据源是一个c3p0 ComboPooledDataSource
。
sql语句具有以下批处理功能:
dataSource.getConnection().getCopyAPI().copyIn(sql, items); //pseudocode
现在,为了进一步提高数据库插入速度(预处理后要导入数百GB),我正在尝试在异步线程中发送copyIn
命令。
但是,如果数据库位于单个磁盘文件系统上,这有意义吗? 这样会提高性能吗?
以及如何实际验证copyIn是否正在并行使用连接池?
我尝试了VisualVM
MBeans
屏幕,在这里我可以看到一个PooledDataSource
条目。 但是,我怎么知道该池已被使用并且项目已并行发送到数据库?
但是,如果数据库位于单个磁盘文件系统上,这有意义吗? 这样会提高性能吗?
如果它正在生锈,可能不会,并且在大量并发中肯定没有什么好处。 对于固态硬盘,有时会产生很大的改进。 在很大程度上取决于驱动器。
我尝试了VisualVM MBeans屏幕,在这里我可以看到一个PooledDataSource条目。 但是,我怎么知道该池已被使用并且项目已并行发送到数据库?
查看数据库中的pg_stat_activity
,看看应用程序中是否有多个并发的COPY
命令。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.