在传统的客户端/服务器体系结构中,用户会话和数据库连接之间是一对一的通信。但在基于 Web的系统中,情况可能有所不同。
基于 Web的系统在本质上是“无状态”的 —当您访问页面时,将建立与数据库的连接,页面下载完成后,将切断与数据库的连接。稍后,当用户再次单击页面时,将建立一个新的连接,目的达到后又将切断连接。这一过程使得没有必要维护大量的同步连接。
建立连接的开销很大,因此连接池是这些应用程序的一个重要要求。在这一模式中,当页面需要数据库访问时,会从池中分配一个已经建立的连接。完成工作后,Web会话会将连接返回池中。
但传统的客户端或中间层连接池的问题是:
每个池只限于单个中间层节点。池的大量增长将导致预先分配的数据库服务器过多和数据库服务器内存使用过多。池中的工作负载分配不均。
为避免这些问题,Oracle数据库 11g 提供了一个服务器端池,称为数据库驻留连接池 (DRCP)。DRCP可用于使用 OCI 驱动程序的所有数据库客户端,包括 C、C++和 PHP。 Oracle数据库 11g预先安装有默认的连接池,但是处于关闭状态。要启用它,使用:
SQL> execute dbms_connection_pool.start_pool;
现在,要连接到池中的连接而不是常规会话,您要做的就是在 TNS条目中添加一行 (SERVER=POOLED),如下所示:
PRONE3_POOL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST =prolin3.proligence.com)(PORT = 1521)) (CONNECT_DATA = (SERVER = POOLED) (SID= PRONE3) ) )
现在,更改代码中的 connect字符串,在这一代码中它连接到数据库。使用上面“客户端结果缓存”部分中的示例代码:
private String jdbcURL = "jdbc:oracle:oci8:@PRONE3_POOL";
就这样了。现在,您的应用程序将连接到池而不是服务器。如果您使用瘦客户端且使用标准的 JDBC连接字符串,则可以使用 POOLED子句:
prolin3.proligence.com:1521/orcl:POOLED
在上面的描述中,您启用了 Oracle附带的默认池,选项为默认的。您可以使用提供的 DBMS_CONNECTION_POOL程序包中的 CONFIGURE_POOL过程:
参数
说明
POOL_NAME
池的名称。使用 ‘’(两个单引号用于默认池)
MINSIZE
池中保存会话数量的下限
MAXSIZE
池中会话数量的上限
INCRSIZE
当池中的服务器不可用时,池将创建这一数量的新服务器
SESSION_CACHED_CURSORS
启用会话缓存游标
INACTIVITY_TIMEOUT
如果会话闲置时间达到这一时长,将断开。
MAX_THINK_TIME
当客户端从池中获取一个服务器后,它必须在这一时间段内发出 SQL语句,否则客户端将丢失服务器
MAX_USE_SESSION
从池中取还一个连接的最多次数
MAX_LIFETIME_SESSION
会话的持续时间
查询各个属性的值
select * from dba_cpool_info;
修改某个参数的值
exec dbms_connection_pool.alter_param ('','minsize','10');
恢复所有参数的默认值
exec dbms_connection_pool.restore_defaults;
DRCP 功能非常重要,因为单个池可在一个普通平台上维持数万同步用户。此外,单个池可以在多个客户端和中间层节点间共享,并且在 RAC和 Data Guard环境中,DRCP 和 FAN 事件共同提供了快速的连接故障转移。
DRCP的总结
在实际的使用,如果要使用DRCP,则需要注意在tnsnames.ora中创建两个TNS连接字符串,将前台短的连接都指向DRCP连接,把后台长的连接则向DEDICATED SERVER连接,这样就可以满足一般轻量权的web application.
介绍一下Oracle开发方便的知识,数据库连接池,目前Oracle只支持一个连接池,名为SYS_DEFAULT_CONNECTION_POOL,管理连接池信息是通过一个包DBMS_CONNECTION_POOL来管理的。
首先我们先看看包的相关说明:
SQL> desc dbms_connection_pool
PROCEDURE ALTER_PARAM
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
PARAM_NAME VARCHAR2 IN
PARAM_VALUE VARCHAR2 IN
PROCEDURE CONFIGURE_POOL
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
MINSIZE BINARY_INTEGER IN DEFAULT
MAXSIZE BINARY_INTEGER IN DEFAULT
INCRSIZE BINARY_INTEGER IN DEFAULT
SESSION_CACHED_CURSORS BINARY_INTEGER IN DEFAULT
INACTIVITY_TIMEOUT BINARY_INTEGER IN DEFAULT
MAX_THINK_TIME BINARY_INTEGER IN DEFAULT
MAX_USE_SESSION BINARY_INTEGER IN DEFAULT
MAX_LIFETIME_SESSION BINARY_INTEGER IN DEFAULT
PROCEDURE RESTORE_DEFAULTS
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
PROCEDURE START_POOL
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
PROCEDURE STOP_POOL
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
包里面有5个存储过程。默认Oracle是包含一个缺省的连接池SYS_DEFAULT_CONNECTION_POOL,但是并没有被打开,需要显示的开启连接池,第一步当然就是开启连接池:
begin
dbms_connection_pool.start_pool('SYS_DEFAULT_CONNECTION_POOL');
end;
/
这个操作只需要做一次,下次数据库重启了之后连接池会自动开启的。
打开了连接池之后可以通过系统视图dba_cpool_info进行查询:
SQL>SELECT connection_pool,status FROM DBA_CPOOL_INFO;
CONNECTION_POOL STATUS
-------------------------------------------------------------------------------- ----------------
SYS_DEFAULT_CONNECTION_POOL ACTIVE
当连接池启动了之后,可以通过DBMS_CONNECTION_POOL.CONFIGURE_POOL来查看连接池的相关配置项。
SQL>DESC DBMS_CONNECTION_POOL.CONFIGURE_POOL
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
POOL_NAME VARCHAR2 IN DEFAULT
MINSIZE BINARY_INTEGER IN DEFAULT
MAXSIZE BINARY_INTEGER IN DEFAULT
INCRSIZE BINARY_INTEGER IN DEFAULT
SESSION_CACHED_CURSORS BINARY_INTEGER IN DEFAULT
INACTIVITY_TIMEOUT BINARY_INTEGER IN DEFAULT
MAX_THINK_TIME BINARY_INTEGER IN DEFAULT
MAX_USE_SESSION BINARY_INTEGER IN DEFAULT
MAX_LIFETIME_SESSION BINARY_INTEGER IN DEFAULT
参数说明:
参数 | 说明 |
MINSIZE | 在pool中最小数量的pooled servers,缺省为4 |
MAXSIZE | 在pool中最大数量的pooled servers,缺省为40 |
INCRSIZE | 这个参数是在一个客户端应用需要连接的时候,当pooled servers不可用的状态时候,每次pool增加pooled servers的数目。 |
SESSION_CACHED_CURSORS | 缓存在每个pooled servers上的会话游标的数目,缺省为20 |
INACTIVITY_TIMEOUT | pooled server处于idle状态的最大时间,单位秒,超过这个时间,the server将被停止。缺省为300. |
MAX_THINK_TIME | 在一个客户端从pool中获得一个pooled server之后,如果在MAX_THINK_TIME时间之内没有提交数据库调用的话,这个pooled server将被释放,客户端连接将被停止。缺省为30,单位秒 |
MAX_USE_SESSION | pooled server能够在pool上taken和释放的次数,缺省为5000 |
MAX_LIFETIME_SESSION | The time, in seconds, to live for a pooled server in the pool. The default value is 3600. |
可以使用DBMS_CONNECTION_POOL.CONFIGURE_POOL或DBMS_CONNECTION_POOL.ALTER_PARAM对连接池的设置进行修改。
SQL>begin
dbms_connection_pool.alter_param('SYS_DEFAULT_CONNECTION_POOL','minsize','20');
end;
/
SQL>begin
dbms_connection_pool.alter_param('SYS_DEFAULT_CONNECTION_POOL','maxsize','150');
end;
/
由于只有一个连接池,第一个参数的值可以省略。
系统中有几个系统视图比较有用:
DBA_CPOOL_INFO 这个视图包含着连接池的状态
V$CPOOL_STATS 这个视图包含着连接池的统计信息
V$CPOOL_CC_STATS 这个视图包含着池的连接类型级别统计
修改成功了之后可以查询下连接池信息:
SQL>SELECT CONNECTION_POOL,STATUS,MINSIZE,MAXSIZE FROM DBA_CPOOL_INFO;
CONNECTION_POOL STATUS MINSIZE MAXSIZE
SYS_DEFAULT_CONNECTION_POOL ACTIVE 20 150
到此,连接池的设置和相关修改已经完成.