视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
数据库管理Oracle连接池信息的修改
2020-11-09 13:49:23 责编:小采
文档


最近项目中用到的Oracle数据库在服务器上是建了多个表空间供不同系统使用,两个系统同时在使用过程中,正在开发的一个项目在测试运行时,时不时就出现连接池满了,连接不上的问题,为此查了下怎么修改Oracle连接池配置的修改方式,特记录下来备查。 目前Orac

最近项目中用到的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> 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

  参数说明:

参数 说明

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

CONNECTION_POOL STATUS MINSIZE MAXSIZE

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

SYS_DEFAULT_CONNECTION_POOL ACTIVE 10 100

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

下载本文
显示全文
专题