oracle10g的默认最大连接数居然是150,很丢人。手动在em控制台修改了初始化参数,改成了15000,重启数据库,再查看 process 是 15000,可是隔夜后,查看又变回150了,几次三翻这样,气死人了。
2011-2-16 编辑:又上服务器查了一下,processes 是15000,没有变化,但依然报400循环错误,看日志,好象看到有 jdbc 疑似有问题,于是便把 classes1.2 换成了 ojdbc6...,再等待一下,看今天系统会不会崩溃。
2011-2-17 编辑:今天没出问题,难道真是驱动版本的问题?
2011-2-20 编辑:NND 问题还是老问题,需要改 open_cursors 数量从300 改到 30000,保存后,重启数据库后,仍然为 30000,压力测试下实际使用了1600个左右,终于搞明白了。
==============================================
实际上,这个错误的原因,主要还是代码问题引起的。
ora-01000: maximum open cursors exceeded.
表示已经达到一个进程打开的最大游标数。
这样的错误很容易出现在Java代码中的主要原因是:Java代码在执行conn.createStatement()和conn.prepareStatement()的时候,实际上都是相当与在数据库中打开了一个cursor。尤其是,如果你的createStatement和prepareStatement是在一个循环里面的话,就会非常容易出现这个问题。因为游标一直在不停的打开,而且没有关闭。
一般来说,我们在写Java代码的时候,createStatement和prepareStatement都应该要放在循环外面,而且使用了这些Statment后,及时关闭。最好是在执行了一次executeQuery、executeUpdate等之后,如果不需要使用结果集(ResultSet)的数据,就马上将Statment关闭。
对于出现ORA-01000错误这种情况,单纯的加大open_cursors并不是好办法,那只是治标不治本。实际上,代码中的隐患并没有解除。
而且,绝大部分情况下,open_cursors只需要设置一个比较小的值,就足够使用了,除非有非常特别的要求。
==============================================
在 oracle中,要经常查看process:
查看ORACLE最大进程数:
SQL> select count(*) from v$session #连接数
SQL> Select count(*) from v$session where status='ACTIVE' #并发连接数
SQL> show parameter processes #最大连接
SQL> alter system set processes = value scope = spfile;重启数据库 #修改连接
unix 1个用户session 对应一个操作系统 process
而 windows体现在线程
------------------------------------------------------------------------------
修改ORACLE最大进程数:
使用sys,以sysdba权限登录:
SQL> show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL> alter system set processes=300 scope = spfile;
系统已更改。
SQL> show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL> create pfile from spfile;
文件已创建。
重启数据库,
SQL> show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 300
--查看当前有哪些用户正在使用数据
SELECT osuser, a.username,cpu_time/executions/1000000||'s', sql_fulltext,machine
from v$session a, v$sqlarea b
where a.sql_address =b.address order by cpu_time/executions desc;
还有可以查询
select sessions_highwater from v$license;
sessions_highwater 记录的是数据库会话曾经达到的最大值
查询数据库自启动以来最大的并发数量
select * from v$license
分享到:
相关推荐
Micrium-TI-uCOS-II-LCD-TMS470R1B1M PORT TO TMS470
Multicore DSP_From Algorithms to Real-time Implementation on the TMS320C66x SoC
资源分类:Python库 所属语言:Python 资源全名:tencentcloud-sdk-python-tms-3.0.408.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
python库。 资源全名:tencentcloud-sdk-python-tms-3.0.307.tar.gz
Real-Time-Digital-Signal-Processing-Implementations-Application-and-Experiments-with-the-TMS320C55X.pdf
Single-phase-inverter-DSP-TMS320F28335-master_inverterdsp_f28335
TI C2833x介绍---HRPWM介绍_TMS320F28335_TIC2833x介绍.zip
TI C2833x介绍---HRPWM介绍_TMS320F28335_TIC2833x介绍_源码.zip
Tms全系列(2019-1-24).rar
17 TMS320C665x + Artix-7 底板B2B连接器24 18 TMS320C665x + Artix-7 SRIO接口 19 TMS320C665x + Artix-7 PCIe接口 20 TMS320C665x + Artix-7 模式调试接口 21 TMS320C665x + Artix-7 XADC接口 22 TMS320C665x + ...
行业分类-设备装置-基于TMS320DM642平台的瞳孔测谎仪.zip
资源来自pypi官网。 资源全名:tencentcloud-sdk-python-tms-3.0.461.tar.gz
资源来自pypi官网。 资源全名:tencentcloud-sdk-python-tms-3.0.355.tar.gz
本技术文档由广州创龙结合TI KeyStone系列多核架构TMS320C665x及Xilinx Artix-7系列FPGA设计的TL665xF-EasyEVM开发板基础上主要讲述以下硬件方面: ...10 TMS320C665x + Artix-7 启动拨码开关 等图文讲解。
The F2802x Piccolo™ family of microcontrollers
TI-datasheet-tms320vc33 TI-datasheet-tms320vc33
μC_OS-Π在DSP芯片TMS320F2812的移植及应用.pdf
FPGA Peripheral Expansion& FPGA Co-Processing with a TI TMS3200C6000
人工智人-家居设计-基于TMS320F2812的电动汽车智能充电系统的研究及实现.pdf