目前Oracle只支持一个连接池,pool name为“SYS_DEFAULT_CONNECTION_POOL”,管理连接池信息的也就一个包“DBMS_CONNECTION_POOL”。
先看看包的相关说明:
SQL> desc DBMS_CONNECTION_POOLElement Type---------------- ---------ALTER_PARAM PROCEDURECONFIGURE_POOL PROCEDURERESTORE_DEFAULTS PROCEDURESTART_POOL PROCEDURESTOP_POOL PROCEDURE包里面有5个存储过程。默认Oracle是包含一个缺省的连接池SYS_DEFAULT_CONNECTION_POOL,但是并没有被打开,需要显示的开启连接池,第一步当然就是开启连接池:
exec DBMS_CONNECTION_POOL.START_POOL('SYS_DEFAULT_CONNECTION_POOL');这个操作只需要做一次,下次数据库重启了之后连接池会自动开启的。
打开了连接池之后可以通过系统视图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_POOLParameter Type Mode Default?---------------------- -------------- ---- --------POOL_NAME VARCHAR2 IN YMINSIZE BINARY_INTEGER IN YMAXSIZE BINARY_INTEGER IN YINCRSIZE BINARY_INTEGER IN Ysession_CACHED_CURSORS BINARY_INTEGER IN YINACTIVITY_TIMEOUT BINARY_INTEGER IN YMAX_THINK_TIME BINARY_INTEGER IN YMAX_USE_SESSION BINARY_INTEGER IN YMAX_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. The default 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_PARAMParameter Type Mode Default?----------- -------- ---- --------POOL_NAME VARCHAR2 IN YPARAM_NAME VARCHAR2 INPARAM_VALUE VARCHAR2 INSQL> exec DBMS_CONNECTION_POOL.ALTER_PARAM ('','minsize','10');PL/SQL procedure successfully completedSQL> 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到此,连接池的设置和相关修改已经完成。
新闻热点
疑难解答