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_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.
一个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
到此,连接池的设置和相关修改已经完成.

 


pxboracle@live.com
2014.08.15 09:06
share you knowledge with the world.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12798004/viewspace-1251572/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/12798004/viewspace-1251572/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值