0

0

Oracle 11g DRCP连接方式基本原理

php中文网

php中文网

发布时间:2016-06-07 17:15:24

|

1213人浏览过

|

来源于php中文网

原创

学习Oracle是一个复杂、繁琐的过程。在浩如烟海的Oracle官方资料、新特性、MOS资料和各种Internal知识面前,我们总是觉得力不从心

学习oracle是一个复杂、繁琐的过程。在浩如烟海的oracle官方资料、新特性、mos资料和各种internal知识面前,我们总是觉得力不从心、不知所措。但是,这往往也就是我们不断坚持、积累和追寻的乐趣。
 
在oracle 11g中,提出了突破传统专用/共享连接的第三种连接方式——database resident connection pooling(drcp)。本篇我们一起来探讨这项技术。
 
1、从dedicated server到shared server
 
oracle client process连接到server process的方式,传统上有两种方式:dedicated server和shared server。在client连入到oracle server的过程中,默认是通过监听器listener监听器进行oracle实例服务定位。只有再由监听器fork出的子进程向instance请求出一个server process与client process远程通信。不同的连接方式,就体现在数据库实例在接受到server process请求后,是怎么样提供出server process进程,以及该进程如何管理的。
 
dedicated server模式也称为专用连接方式,就是oracle instance会专门创建出一个新的server process与client process进行远程通信。在整个client process请求过程中,server process只为该client提供服务。uga信息也保存在server process的pga空间中。当会话结束,client连接中断,server process就失去“存在意义”被清除掉,分配内存回收。dedicated方式是我们最常使用的数据库连接方式。在长会话或前端应用使用连接池组件的情况下,dedicated方式的优势是很明显的。
 
与dedicated server模式对应的是shared server。在该模式下,oracle实例会维持两种server process:分发进程(dispatcher dxxx)和共享进程(sxxx)。
 
 
sql> select addr, pid, spid, username, program from v$process where program like '%000%';
 
addr           pid spid        username       program
-------- ---------- ------------ --------------- --------------------
6d24ba1c        13 648         system         oracle.exe (d000)
6d24c00c        14 1736        system         oracle.exe (s000)
 
 
 
当监听器向数据库实例提出server process分配请求的时候,在shared server模式下,监听器会向分发进程dxxx请求分配server process。dxxx会根据当前的空闲server情况,分配出一个server process供使用。当client使用结束之后,server process(sxxx)并不是被释放,而是重新回到d000管制下。系统也会依据参数设置,维持一个稳定的sxxx数量。
 
 
sql> show parameter shared_servers
 
name                                type       value
------------------------------------ ----------- ------------------------------
max_shared_servers                  integer   
shared_servers                      integer    1
 
 
shared server连接模式的出现,是和短会话、高并发的互联网应用发展相关。每次创建和回收server process的成本是很高的。如果应用没有中间层连接池,而是高并发的创建server process并且快速回收,这对于数据库来说是很高的压力。
 
从现在的应用设计开发看,连接池管理已经渗透入主流应用系统框架,shared server方式实际中应用不是很广泛。
 
2、database resident connection pooling(drcp)
 
如果我们站在软件模式的角度看,shared server本质上也是想实现一种在数据库层面上的连接池。这点在oracle 11g上得到了实现,oracle驻留连接池(drcp)就是一个允许在多进程(multi-process)和多线程(multi-threads)之间共享连接的新特性。
 
shared server在一定程度上缓解了server process idel和频繁创建销毁server process的问题。但是,shared server没有解决session数据共享的问题。当存在client需要长时间持有session,,同时其他client没有大量会话要求的时候,这种模型是有效的。但是,在每次请求会话的时间很短(短会话)和数据库活动需要多次会话交互的时候,drcp就是更加理想的连接池模型了。
 
drcp新特性主要针对的就是应用程序在访问数据库时,出现高并发连接数问题。drcp连接池将server和session信息进行缓存,为多个访问的应用程序提供连接共享。
 
同shared server一样,drcp前端存在一个代理(connection broker),负责应用中间件连接的共享要求,同时负责管理数据库实例上的连接池连接。当应用中间件想broker提出连接请求的时候,broker会从连接池中找出空闲连接。当交互结束后,server process被释放回连接池供重用。
 
同shared server不同的方面在于。当共享池中连接池被分配出之后,等价于dedicated server方式。

linux

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

Golang 性能优化专题:提升应用效率
Golang 性能优化专题:提升应用效率

《Golang 性能优化专题》聚焦 Go 应用在高并发与大规模服务中的性能问题,从 profiling、内存分配、Goroutine 调度、GC 机制到 I/O 与锁竞争逐层分析。结合真实案例讲解定位瓶颈的方法与优化策略,帮助开发者建立系统化性能调优思维,在保证代码可维护性的同时显著提升服务吞吐与稳定性。

2

2026.02.24

Golang 面试题精选:高频问题与解答
Golang 面试题精选:高频问题与解答

Golang 面试题精选》系统整理企业常见 Go 技术面试问题,覆盖语言基础、并发模型、内存与调度机制、网络编程、工程实践与性能优化等核心知识点。每道题不仅给出答案,还拆解背后的设计原理与考察思路,帮助读者建立完整知识结构,在面试与实际开发中都能更从容应对复杂问题。

1

2026.02.24

Golang 运行与部署实战:从本地到云端
Golang 运行与部署实战:从本地到云端

《Golang 运行与部署实战》围绕 Go 应用从开发完成到稳定上线的完整流程展开,系统讲解编译构建、环境配置、日志与配置管理、容器化部署以及常见运维问题处理。结合真实项目场景,拆解自动化构建与持续部署思路,帮助开发者建立可靠的发布流程,提升服务稳定性与可维护性。

3

2026.02.24

Golang 疑难杂症解决指南:常见问题排查与优化
Golang 疑难杂症解决指南:常见问题排查与优化

《Golang 疑难杂症解决指南》聚焦开发过程中常见却棘手的问题,从并发模型、内存管理、性能瓶颈到工程化实践逐步拆解。通过真实案例与调试思路,帮助开发者定位问题根因,建立系统化排查方法。不只给出答案,更强调分析路径与工具使用,让你在复杂 Go 项目中具备持续解决问题的能力。

1

2026.02.24

Golang 入门学习路线:从零基础到上手开发
Golang 入门学习路线:从零基础到上手开发

Golang 入门路线涵盖从零到上手的核心路径:首先打牢基础语法与切片等底层机制;随后攻克 Go 的灵魂——接口设计与 Goroutine 并发模型;接着通过 Gin 框架与 GORM 深入 Web 开发实战;最后在微服务与云原生工具开发中进阶,旨在培养具备高性能并发处理能力的后端工程师。

0

2026.02.24

中国研究生招生信息网官方网站入口 研招网网页版在线入口
中国研究生招生信息网官方网站入口 研招网网页版在线入口

中国研究生招生信息网入口(https://yz.chsi.com.cn) 此网站是研究生报名入口的唯一官方网站

95

2026.02.24

苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法
苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法

本专题汇总苹果官网最新可用入口及中国站点访问方式,涵盖官网直达链接、iPhone官方页面查看方法与常见访问说明,帮助用户快速进入苹果官方网站,便捷了解产品信息与官方服务。

14

2026.02.24

Asianfanfics官网入口与访问指南_AFF官方平台最新登录地址
Asianfanfics官网入口与访问指南_AFF官方平台最新登录地址

本专题系统整理Asianfanfics(AFF)官方网站最新可用入口,涵盖官方平台最新直达地址、官网登录方式及中文访问指引,帮助用户快速、安全地进入AFF平台浏览与使用相关内容。

15

2026.02.24

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 4.5万人学习

SQL 教程
SQL 教程

共61课时 | 4万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

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

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