`

Oracle创建连接过慢的问题

 
阅读更多

近日,公司ORACLE服务器突如其来的宕机了,经过重装一系列的折腾终于解决了。终于发现自己对ORACLE理解还不够。

 

先列举一下几个问题的解决方案:

问题一:ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务

解决方案:通过重启服务的方式启动数据库,尝试连接。如果未解决修改listener.ora文件,配置静态监听。

总结:正确添加listener.ora;重新启动了oracle服务器,并检查oracle所有服务是否启动;oracle客户端Net Cofiguration Assistant正确添加或重新配置实例名 

 

问题二:ORA-12518: TNS: 监听程序无法分发客户机连接

解决方案:一般出现此情况较少,首先检查数据库服务是否启动 ,如果数据库服务启动请通过sqlplus命令登录dba执行startup命令启动数据库实例。

cmd>sqlplus connect sys/sys as sysdba>startup

 

问题三:通过plsql等工具连接oracle速度慢,需要10几秒以上,甚至长时间连接不上,通过命令启动和关闭oralce侦听时连接也很慢。

解决方案:这种情况发生通常有两种情况,

第一种是机器名(hostname)的问题,需要修改listener.ora文件或者重新建立监听即可。

第二种方式是我此次遇到的问题,oracle多个人开发用,持续时间比较久,侦听日至过大,导致连接慢。这种方法的解决方案是删除或重命名原有侦听日至。

lsnrctl set log_status off

rename listener.log listener.old

lsnrctl set log_status on 

 

总结一下新了解到的知识:

1.在windows中,windows服务中的oracle服务启动了不代表oracle实例一样启动了。

开始菜单->oracle配置和移植工具->Administration Assistant for Windows

左侧菜单上找到数据库菜单,下方实例上右键启动关闭选项。

oracle实例选项卡中有"服务启动时启动实例",和"服务停止时关闭实例"两个选项。

 

2.oracle相关命令

#启动监听

lsnrctl start

#关闭监听

lsnrctl stop

用lsnrctl reload重启监听器,此命令可以代替lsnrctl stop和lsnrctl start。重启将会在不需要关闭和启动监听器的情况下读取listener.ora的配置。

 

#启动oradb数据库服务

net start OracleServiceORCL

#关闭oradb数据库服务

net stop OracleServiceORCL

 

#启动dbconsole服务

emctl start dbconsole

#停止dbconsole服务

emctl stop dbconsole

 

#启动数据库

system>sqlplus connect sys/sys as sysdba

sql>startup

 

#停止数据库

sql>shutdown immediate

 

要启动或者停止服务,必须拥有sysdba的权限。

 

 

 

shutdown命令参数:

Normal 需要等待所有的用户断开连接,需要在所有连接用户断开后才执行关闭数据库任务,所以有的时候看起来好象命令没有运行一样!在执行这个命令后不允许新的连接.

Immediate 等待用户完成当前的语句 (推荐),在用户执行完正在执行的语句后就断开用户连接,并不允许新用户连接。 

Transactional 等待用户完成当前的事务,在拥护执行完当前事物后断开连接,并不允许新的用户连接数据库。  

Abort 不做任何等待,直接关闭数据库,执行强行断开连接并直接关闭数据库。

 

前三种方式不会丢失用户数据。第四种情况对于紧急关闭数据库才使用。

 

 

 

数据库的启动

数据库启动使用startup命令,它有三种情况 

第一种:不带参数,启动数据库实例并打开数据库,以便用户使用数据库,在多数情况下,使用这种方式! 

第二种:带nomount参数,只启动数据库实例,但不打开数据库,在你希望创建一个新的数据库时使用,或者在你需要这样的时候使用! 

第三种:带mount参数,在进行数据库更名的时候采用。这个时候数据库就打开并可以使用了! 

 

其他问题:

 

提示:环境变量 ORACLE_SID 未定义,请定义。

设置 ORACLE_SID =WLW (WLW是我的实例名,也是服务名) C:\Documents and Settings\xcl>set ORACLE_SID=WLW(注意大写)

Oracle 10g错误:shared memory realm does not exist的分析与解决容,情况是这样的:在连接Oracle 10g时出现了错误:“shared memory realm does not exist”,如下图所示:

 

硬盘格式的文件存储文件限制:

NTFS(Windows):支持最大分区2TB,最大文件2TB

FAT16(Windows):支持最大分区2GB,最大文件2GB

FAT32(Windows):支持最大分区128GB,最大文件4GB

HPFS(OS/2):支持最大分区2TB,最大文件2GB

EXT2和EXT3(Linux):支持最大分区4TB,最大文件2GB

JFS(AIX):支持最大分区4P(block size=4k),最大文件4P

XFS(IRIX):这是个正经的64位的文件系统,可以支持9E(2的63次方)的分区

 

博客地址:http://www.hrblive.com/coder/blog/blog_149.html,转载请注明出处。

分享到:
评论

相关推荐

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    说明:Oracle中需要创建用户一定是要具有dba(数据库管理员)权限的用户才能创建,而且创建的新用户不具备任何权限,连登录都不可以。 用法:create user 新用户名 identified by 密码 例子: 2. 修改密码 说明:...

    方便高效实用的远程数据库对象(delphi 版)

    ps : 就是连接Oracle和mysql,客户端也可以不用装驱动哦 使用步骤 解压后找个地方存放 将GobUnit目录添加到delphi的搜索路径 将DXSockEnt30(我改过bug的版本)的3个子目录也添加到delphi的搜索路径 即可使用和编译...

    简单的ADO.net数据访问客户端

    类似的,可以创建访问Oracle,Sqlite或是其他数据库的客户端,只需要找到对应的DbProviderFactory实例即可。 基本数据库操作 基础CRUD // 查询 string productName = (string)Db.Northwind.Scalar( "SELECT ...

    mysql数据库my.cnf配置文件

    可以过'conn%'通配符查看当前状态的连接数量,以定夺该值的大小。 max_connect_errors = 6000 # 对于同一主机,如果有超出该参数值个数的中断错误连接,则该主机将被禁止连接。如需对该主机进行解禁,执行:FLUSH ...

    Toad 使用快速入门

    从网络服务器读取Toad程序,在本地计算机安装一些自定义的文件,并且创建到服务器文件的快捷方式,一般不推荐使用这个方式,而且要求网络服务器已经配置。 c) TOAD to Network Server 把Toad安装到网络服务器上,...

    经典全面的SQL语句大全

     对存储在数据库中的数据来说,随机数特性能给出上面的效果,但它们可能太慢了些。你不能要求ASP“找个随机数”然后打印出来。实际上常见的解决方案是建立如下所示的循环: Randomize RNumber = Int(Rnd*499) +1 ...

    vfp6.0系统免费下载

    问题 2-8: 是否可以在 Visual FoxPro 6.0 中创建用户自定义集合? 答案: Visual FoxPro 5.0 不直接支持创建类似于对象数组的集合。Form 对象的 Controls 属性就是一种集合。Visual FoxPro 6.0 支持 Access/Assign ...

    MySQL管理之道 性能调优、高可用与监控.part2.rar

    不论你目前有没有遇到过此类问题,相信对你以后处理相关问题都会有所借鉴。本书适合所有希望构建和管理高性能、高可用性的mysql数据库系统的开发者和dba阅读。 目录 · · · · · · 前言 第一部分 mysql5.5 新...

    超级有影响力霸气的Java面试题大全文档

    例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。 当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望...

    PHP基础教程 是一个比较有价值的PHP新手教程!

    你可以利用PHP连接包括Oracle,MS-Access,Mysql在内的大部分数据库。你可以在苍蝇上画图,编写程序下载或者显示e-mail。你甚至可以完成网络相关的功能。最好的是,你可以选择你的PHP安装版本需要哪些功能。引用...

    java 面试题 总结

    例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。 当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望...

    二十三种设计模式【PDF版】

    你曾经多少次有过这种感觉—你已经解决过了一个问题但就是不能确切知道是在什么地 方或怎么解决的?如果你能记起以前问题的细节和怎么解决它的,你就可以复用以前的经验而不需要重新发现它。然而,我们 并没有很好...

    JAVA面试题最全集

    除了使用new关键字创建对象意外,试列举另外三种以上创建实例的方式? 37.classloader中,JDK的API、Classpath中的同web-inf中的class加载方式有什么区别? 38.列举三种以上垃圾回收算法,并比较其优缺点? 39....

    网管教程 从入门到精通软件篇.txt

    除非您访问驱动器有问题,否则不要继续进行。向系统分区写入新的主引导记录可能破坏分区表并导致分区无法访问。  format  将指定的驱动器格式化为指定的文件系统。含有下列参数的 format 命令仅在使用故障恢复...

Global site tag (gtag.js) - Google Analytics