oracle连接池管理包,数据库管理Oracle 连接池信息的修改

目前Oracle只支持一个连接池,pool name为“SYS_DEFAULT_CONNECTION_POOL”,管理连接池信息的也就一个包“DBMS_CONNECTION_POOL”。

先看看包的相关说明:

SQL>desc DBMS_CONNECTION_POOL

Element Type-------------------------ALTER_PARAM PROCEDURE

CONFIGURE_POOL PROCEDURE

RESTORE_DEFAULTS PROCEDURE

START_POOL PROCEDURE

STOP_POOL PROCEDURE

包里面有5个存储过程。默认Oracle是包含一个缺省的连接池SYS_DEFAULT_CONNECTION_POOL,但是并没有被打开,需要显示的开启连接池,第一步当然就是开启连接池:

exec DBMS_CONNECTION_POOL.START_POOL('SYS_DEFAULT_CONNECTION_POOL');

这个操作只需要做一次,下次数据库重启了之后连接池会自动开启的。

打开了连接池之后可以通过系统视图dba_cpool_info进行查询:

SQL>selectconnection_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

Parameter Type Mode Default?------------------------------------------------POOL_NAME VARCHAR2 IN Y

MINSIZE BINARY_INTEGER IN Y

MAXSIZE BINARY_INTEGER IN Y

INCRSIZE BINARY_INTEGER IN Y

SESSION_CACHED_CURSORS BINARY_INTEGER IN Y

INACTIVITY_TIMEOUT BINARY_INTEGER IN Y

MAX_THINK_TIME BINARY_INTEGER IN Y

MAX_USE_SESSION BINARY_INTEGER IN Y

MAX_LIFETIME_SESSION BINARY_INTEGER IN Y

参数说明:

参数                         说明

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. Thedefault value is 3600.一个pooled server在pool中的生命值。

注:在pooled server数目不能低于MINSIZE。

可以使用DBMS_CONNECTION_POOL.CONFIGURE_POOL或DBMS_CONNECTION_POOL.ALTER_PARAM对连接池的设置进行修改。

先来看看参数信息:

SQL>desc DBMS_CONNECTION_POOL.ALTER_PARAM

Parameter Type Mode Default?-------------------------------POOL_NAME VARCHAR2 IN Y

PARAM_NAME VARCHAR2 IN

PARAM_VALUE VARCHAR2 IN

SQL>exec DBMS_CONNECTION_POOL.ALTER_PARAM ('','minsize','10');PL/SQL procedure successfully completed

SQL>exec DBMS_CONNECTION_POOL.ALTER_PARAM ('','maxsize','100');PL/SQL procedure successfully completed

由于只有一个连接池,第一个参数的值可以省略。

系统中有几个系统视图比较有用:

DBA_CPOOL_INFO 这个视图包含着连接池的状态

V$CPOOL_STATS 这个视图包含着连接池的统计信息

V$CPOOL_CC_STATS 这个视图包含着池的连接类型级别统计

修改成功了之后可以查询下连接池信息:

SQL>selectCONNECTION_POOL, STATUS,MINSIZE,MAXSIZE from DBA_CPOOL_INFO;

CONNECTION_POOL STATUS MINSIZE MAXSIZE--------------------------------------------------------------------------------------------------------------------SYS_DEFAULT_CONNECTION_POOL ACTIVE10100

到此,连接池的设置和相关修改已经完成。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值