您的位置:首页 > 数据库 > Oracle

Oracle 连接池配置

2016-03-21 10:33 441 查看
Oracle 连接池配置

分类: Oracle

介绍一下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_TIMEOUTpooled server处于idle状态的最大时间,单位秒,超过这个时间,the server将被停止。缺省为300.
MAX_THINK_TIME在一个客户端从pool中获得一个pooled server之后,如果在MAX_THINK_TIME时间之内没有提交数据库调用的话,这个pooled server将被释放,客户端连接将被停止。缺省为30,单位秒
MAX_USE_SESSIONpooled server能够在pool上taken和释放的次数,缺省为5000
MAX_LIFETIME_SESSIONThe time, in seconds, to live for a pooled server in the pool. The default value is 3600.

一个pooled server在pool中的生命值。
可以使用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

到此,连接池的设置和相关修改已经完成.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: