0

0

如何配置Oracle网络连接池_Shared Server共享服务器模式解析

P粉602998670

P粉602998670

发布时间:2026-03-15 18:13:32

|

938人浏览过

|

来源于php中文网

原创

Shared Server 是 Oracle 的连接多路复用模式,多个客户端共享一组 Shared Server 进程,通过 Dispatcher 转发请求;它与传统连接池不兼容,因连接池管理的“物理连接”实为到 Dispatcher 的会话通道,并非独占服务进程,且连接有效性验证、预热、最小空闲等机制会加剧 Dispatcher 压力并引发 ORA-12520 等调度资源不足错误。

oracle shared server 模式下不能直接复用传统连接池(如 ucp、hikaricp)的“物理连接”语义,因为客户端连的是调度进程 sdu,后端会动态分配 shared server 进程处理请求,连接池看到的“连接”实际是到监听器的会话通道,不是独占的服务器进程。

Shared Server 是什么,为什么它和连接池不兼容

Shared Server 模式本质是“连接多路复用”:多个客户端共用一组 Shared Server 进程,通过 Dispatcher 转发请求。这导致两个关键事实:

  • 客户端建立的 TCP 连接始终指向 Dispatcher(监听地址仍是 localhost:1521),不是直连 Pmon 或某个固定服务进程
  • UCPOracle JDBC Thin 驱动默认按 Dedicated Server 行为验证连接有效性(比如执行 SELECT 1 FROM DUAL),但在 Shared Server 下,短时空闲连接可能被 Dispatcher 断开,而连接池仍认为它“可用”
  • 连接池的“最小空闲数”策略容易触发 ORA-12520: TNS:listener could not find available handler,因为 Dispatcher 的并发处理能力受 MAX_DISPATCHERSSHARED_SERVERS 限制,不是无限伸缩

如何让 UCP(Universal Connection Pool)适配 Shared Server

UCP 本身支持 Shared Server,但必须关闭自动连接验证和预热逻辑,否则会在后台不断试探连接,加剧 Dispatcher 压力:

  • 禁用连接验证:pool.setValidateConnectionOnBorrow(false);改用应用层轻量心跳(例如在业务线程中定期发 SELECT SYSDATE FROM DUAL
  • 关闭连接创建时的预校验:pool.setInitialPoolSize(0),避免启动时批量建连压垮 Dispatcher
  • 显式指定网络服务名走 Shared Server:JDBC URL 中必须含 (SERVER=shared),例如 jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=myhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=mydb)(SERVER=shared)))
  • 设置合理的最大连接数:pool.setMaxPoolSize() 建议 ≤ SHARED_SERVERS * 2,避免排队过长;可通过 V$DISPATCHER 查看当前 SERVERS 实际值

Shared Server 下 tnsnames.oralistener.ora 必须改哪些配置

如果 JDBC URL 用的是别名(如 @MYDB),则 tnsnames.ora 必须显式声明 SERVER=shared,否则默认走 Dedicated:

MYDB =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = myhost)(PORT = 1521))
    (CONNECT_DATA =
      (SERVICE_NAME = mydb)
      (SERVER = shared)
    )
  )

listener.ora 则需确认已启用 Dispatcher,且未禁用共享模式:

DeepSider
DeepSider

浏览器AI侧边栏对话插件,集成多个AI大模型

下载
  • 检查 LISTENER 是否包含 DEDICATED_SERVERS=0(可选,但建议设为 0 以强制共享)
  • 确认数据库参数 dispatchers 已设置,例如 ALTER SYSTEM SET dispatchers='(PROTOCOL=TCP)(DISPATCHERS=4)'
  • 运行 lsnrctl services,输出中应出现 Dispatcher 条目,且状态为 ready,而非仅显示 Dedicated

为什么你看到 ORA-12519ORA-12520 却查不到连接泄漏

这两个错误根本不是连接没关,而是 Dispatcher 队列满或 Shared Server 进程耗尽。排查路径很窄:

  • V$QUEUE:如果 WAIT 列持续 > 0,说明请求在 Dispatcher 队列里堆积
  • V$SHARED_SERVER:看 STATUS 是否大量为 QUITRECREATING,表示进程频繁崩溃
  • V$DISPATCHERBUSY / IDLE 比,若长期 BUSY > 90%,说明 Dispatcher 数不够,不是连接池问题
  • JDBC 层调用 connection.close() 后,实际只是归还到 UCP 池,并不释放到 Dispatcher —— 所以连接池大小和 SHARED_SERVERS 的配比,比“有没有 close”重要得多

Shared Server 的复杂点不在配置语法,而在于它把“连接生命周期”的控制权从应用移交给了 Oracle 网络层。你调 close(),Oracle 不一定真断;你设 maxPoolSize=50,Oracle 可能只用 8 个 Shared Server 就扛住了——前提是调度和队列没卡死。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

786

2023.08.10

oracle清空表数据
oracle清空表数据

当表中的数据不需要时,则应该删除该数据并释放所占用的空间。本专题为大家提供oracle清空表数据的相关文章,帮助大家解决该问题。

271

2023.08.16

Oracle中declare的使用
Oracle中declare的使用

Oracle DECLARE语句是PL/SQL编程语言中用于声明变量、常量、游标或异常的关键字。它的主要作用是在程序中定义这些对象,以便在后续的代码中使用。DECLARE语句的语法简单明了,可以根据需要声明多个对象。通过使用这些声明的对象,可以进行各种操作,如计算、查询数据库、处理异常等 。

221

2023.09.15

oracle怎么分页
oracle怎么分页

实现分页的步骤:1、使用ROWNUM进行分页查询;2、在执行查询之前进行设置分页参数;3、使用"COUNT(*)"函数来获取总行数,并使用"CEIL"函数来向上取整计算总页数;4、在外部查询中使用"WHERE"子句来筛选出特定的行号范围,以实现分页查询。想了解更多oracle怎么分页的文章,可以来阅读本专题先的文章。

246

2023.09.18

Oracle查看表操作历史记录
Oracle查看表操作历史记录

查看操作历史记录的方法:1、使用Oracle内置的审计功能,可以记录数据库中发生的各种操作,包括登录、DDL语句、DML语句等;2、使用Oracle日志文件,其中包含了数据库中发生的各种操作,可以通过查看日志文件来获取操作历史记录;3、使用Oracle的Flashback功能,可以查看数据库在某个时间点的操作历史记录;4、使用第三方工具等。本专题还提供其他查看表操作的文章,大家可以免费阅读。

464

2023.09.19

Oracle中RAC的用法
Oracle中RAC的用法

Oracle中RAC的用法:1、通过在多个服务器上运行数据库实例来提供高可用性;2、允许在需要时增加或减少节点数量;3、通过将工作负载分布到多个节点上来实现负载均衡;4、使用共享存储来实现多个节点之间的数据共享;5、允许多个节点同时处理数据库请求,从而实现并行处理;6、提供了透明故障切换功能;7、使用了一些技术来确保数据的一致性;8、提供了管理工具来简化RAC环境的管理和维护。本专题还提供RAC相关的其他文章,大家可以免费阅读。

451

2023.09.19

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号