首页 > 大数据 > 正文

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

2012-07-03 16:08:42  来源:悠虎

摘要:最近项目中用到的Oracle数据库在服务器上是建了多个表空间供不同系统使用,两个系统同时在使用过程中,正在开发的一个项目在测试运行时,时不时就出现连接池满了....
关键词: 数据库 Oracle

    最近项目中用到的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进行查询:


[page]    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


    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


    参数说明:


    参数 说明


[page]    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


[page]    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> select CONNECTION_POOL, STATUS,MINSIZE,MAXSIZE from DBA_CPOOL_INFO;


    CONNECTION_POOL STATUS MINSIZE MAXSIZE


    -------------------------------------------------------------------------------- ---------------- ---------- ----------


    SYS_DEFAULT_CONNECTION_POOL ACTIVE 10 100


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


第三十八届CIO班招生
国际CIO认证培训
首席数据官(CDO)认证培训
责编:liangxuejuan

免责声明:本网站(http://www.ciotimes.com/)内容主要来自原创、合作媒体供稿和第三方投稿,凡在本网站出现的信息,均仅供参考。本网站将尽力确保所提供信息的准确性及可靠性,但不保证有关资料的准确性及可靠性,读者在使用前请进一步核实,并对任何自主决定的行为负责。本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。