kettle8.3 Oracle连接运行一段时间后:Socket read timed out

前言

一段SQL在Oracle连接运行大约需要450s。因为业务需要我得运行18次,之前使用kettle8.3默认连接池的方法发现只能运行到一半然后就报错:Socket read timed out。网上的大多不清不楚

解决办法

数据库连接-选项里添加

bash 复制代码
useSSL:true
useCompression:true
rewriteBatchedStatements:true
characterEncoding:utf8
useServerPrepStmts:false
socketTimeout:800000
connectTimeout:800000
ConnectionLifetime:3600000

后三项为主要参数,注socketTimeoutconnectTimeout 参数来设置超时时间。为了适应 450 秒的查询时间,可以将超时时间设置为稍大于 450 秒,这里的 800000 表示 800 秒,单位是毫秒。

数据库连接-连接池 里添加
勾选 使用连接池,除下面用到的其他默认就行

bash 复制代码
初始大小:8;最大空闲空间:20
Initial Size: 5
Max Active Connections: 50
Max Idle Connections: 20
Min Idle Connections: 5
Max Wait Time: 600000 (10分钟)
Connection Lifetime: 3600000 (1小时)
Validation Query: SELECT 1 FROM DUAL

结尾

接下来持续监控性能和日志,关注网络状况和服务器负载,应该能够解决由于超时导致的问题了。

相关推荐
SHIPKING3933 分钟前
【开发策略】MCP 多表查询策略方案
数据库·oracle
kka杰9 分钟前
MYSQL 事务-1
数据库·mysql·oracle
chian_ocean23 分钟前
在 KubeSphere 上部署 AI 大模型 Ollama
数据库
跟着珅聪学java31 分钟前
Jedis SetParams教程:参数化设置 Redis 键值对
数据库·redis·缓存
一颗宁檬不酸32 分钟前
数据库开发实战案例分享:从函数到存储过程的应用
数据库·数据库开发
北京中邦兴业37 分钟前
GMP洁净环境监测法规深度解读:构建以风险为核心的动态防御体系
数据库·人工智能·面试·职场和发展
TDengine (老段)44 分钟前
人力减 60%:时序数据库 TDengine 助力桂冠电力实现 AI 智能巡检
java·大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
潇I洒1 小时前
Ubuntu Linux 24.04 安装MySQL 8.4.7
linux·数据库·mysql·ubuntu
milanyangbo1 小时前
像Git一样管理数据:深入解析数据库并发控制MVCC的实现
服务器·数据库·git·后端·mysql·架构·系统架构
云和恩墨1 小时前
制造企业跨工厂数据库集中管理:3 步破解异构环境同步与监控难题
数据库