oracle数据库的failover是什么意思 , 工作机制是什么?顾名思义如何预防oracle宕机,oracle如何预防oracle宕机的failover是指在oracle集群汇总,客户端当前连接的实例发生故障时,oracle会
自动将连接切换到另外一个实例上的情况 。
或者说,当用户连接到RAC环境时,用户实际是连接到RAC中的一个实例,用户的查询等操作也是由该
实例完成的 , 如果该实例down掉了,那么用户连接会被转移到其他健康实例,而这种转换对于用户是透明
的,用户的select语句仍然继续返回结果集,感觉不到异常 。
可以尝试通过下面实例来体现以下:
1,连接到rac
$
sqlplus
user/password@instance1;
2,
确认用户当前连接的实例
SQL
slect
instance_name
from
v$instance;
instance1;
3,
关闭instance1
SQLshutdown
abort;
4,等待几秒后,在第一次连接的session中继续执行查询如何预防oracle宕机;
SQL
slect
instance_name
from
v$instance;
instance2;
我的oracle宕机了怎么处理1、案例现象
在root用户下,su切换到一个普通用户oracle下,却发生了如下错误:
oracle数据库意外宕机的分析处理案例
于是,尝试直接通过oracle用户登录系统,发现此时的oracle用户也无法登录了,出现与上面同样的错误 。
2、解决思路
从上面错误提示可知是权限出现了问题 , 那么可以从权限入手进行排查,基本思路如下:
用户目录/home/oracle权限问题;
su程序执行权限问题;
程序依赖的共享权限问题;
selinux问题导致;
系统根空间问题 。
3、排查问题
根据上面的思路,我们进行逐一检查,考虑到su在切换到oracle用户时会读取oracle目录下的环境变量配置文件,因此 , 首先检查/home/oralce目录的权限是否存在问题,
[root@loaclhost home]# ls -al/home|grep oracle
drwx---- 4 oralceoinstall 4096 01-31 10:45 oracle
从输出可知,/home/oracle目录的属主是oracle用户,oracle用户对这个目录有“rwx”权限,因此,oracle用户目录的权限设置是正确的 , 可以排除掉这个问题了 。
接着检查su执行权限问题:
[root@loaclhost home]# 11 /bin/su
-rwsr-xr-x 1 root root 24120 2007-11-30 /bin/su
可见su命令执行权限也没有问题,这个也排除了 。
继续检查su依赖的共享库权限 , 使用ldd命令检查su命令依赖的共享库文件 , 如下图
oracle数据库意外宕机的分析处理案例
根据上面的操作,依次检查su命令依赖的每个库文件的权限,发现也都是正常的,因此,共享库的问题也排除了 。
根据上面的思路,绩效检查SELinux的设置 。
oracle数据库意外宕机的分析处理案例
由输出可知,SELinux处于关闭状态,这个原因也排除了 。
到这来为止,问题变得朴素迷离,到底是哪里出现问题了呢?作为Linux运维,例行检查系统根分区状态是非常必要的,那么首先检查一个根分区的磁盘空间大小,发现剩余空间还有很多,空间问题也排除了 。既然报的错误是权限有问题,那么只要以权限为线索,不偏离这个核心就没错,于是继续尝试检查/home目录下各个用户的权限,如下图 。
oracle数据库意外宕机的分析处理案例
从输出看每个用户的目录权限,都是“rwx----”,即“700”,完全没有问题,可是我发现我错了,我的目光一直在用户对应的目录上,而忽略了其他输出信息,而问题就藏在我没有关注的信息中 。在这个命令输出的前两行中 , 第一行权限对应的目录是“.” , 代表当前目录 , 也就是/home目录,权限为“rwxr-xr-x”,第二行权限对应的目录是“..”,也就是根目录,权限却为“rw-rw-rw-” , 即“666”,此时,问题终于查找到了,原来是根目录权限问题 。
4、解决问题
知道了问题产生的原因,解决问题就非常简单,执行如下命令:
[root@localhost~]#chmod 755 /
然后就可顺利执行su切换命令 。
经验分享
这个问题主要是由于根目录没有执行权限,而Linux下所有的操作都是在根目录下进行的,进而导致/home/oralce目录没有执行权限 。其实根目录权限的丢失对于系统中运行的每个用户存在同样的影响 。因此,在权限出现问题时,一定要注意根目录的权限 。
Oracle数据库无响应故障处理方式 Oracle数据库无响应故障处理方式
Oracle数据库无响应故障,简单地讲就是数据库实例不能响应客户端发起的请求,客户端提交一个SQL后,就一直处于等待数据库实例返回结果的状态 。更严重的现象是客户端根本不能连接到数据库,发起一个连接请求后 , 一直处于等待状态 。Oracle数据库无响应故障怎么处理呢?下面跟我一起来学习Oracle数据库无响应故障的处理方法吧!
【如何预防oracle宕机 如何停止oracle服务】无响应的故障现象一般有以下几种:
1.Oracle的进程在等待某个资源或事件
这种现象一般可以从V$SESSION_WAT、V$LATCH、V$LATCHHOLDER等动态视图中检查进程正在等待的资源或事件,而被等待的资源或事件,一直都不能被获取,甚至是很长时间都不可获得 。如果这个正在等待的进程持有了其他的资源,则会引起其他的进程等待 , 这样就很可能引起实例中大范围的会话发生等待 。由于进程在等待资源或事件时 , 通常都处于SLEEP状态,消耗的CPU资源非常少(在等待latch时要稍微多消耗一些CPU资源),所以从OS来看,CPU的消耗并不高,甚至是非常低 。
这种因为等待而引起的个别进程Hang,相对比较容易处理 。
2. OracleProcess Spins
所谓Spin,就是指Oracle进程中的代码在执行某个过程时,陷入了循环 。在V$SESSION视图中 , 往往可以看到Hang住的会话 , 一直处于“ACTIVE”状态 。对于这样的会话,用“alter system kill session ‘sid,serial#’”命令也不能完全断开会话,会话只能被标记为“killed”,会话会继续消耗大量的CPU 。进程Spins由于是在做循环 , CPU的消耗非常大,从OS上明显可以看到这样的进程,通常会消耗整个CPU的资源 。
而对于这样的Hang住的会话,处理起来相对比较复杂,并且为了从根本上解决问题,需要超过DBA日常维护所需要的技能 。
从故障范围来看,无响应故障可以分为以下几种情况:
1. 单个或部分会话(进程)Hang住
这种情况属于小范围的故障,业务影响相对较小,一般来说只会影响业务系统的个别模块 。在一个多应用系统的数据库上面,如果Hang住的会话比较多,则影响的可能是其中的一个应用系统 。这里有一个例外,如果Hang住的进程是系统后台进程,如pmon、smon等,则影响的范围就非常大了 , 最终甚至会影响整个数据库及所有应用系统 。还有值得注意的是,即使是少部分会话Hang?。惨笆贝?,否则极有可能会扩散到整个系统 。
2. 单个数据库实例Hang住
这种情况造成的影响非常大 。在这个实例上的所有应用系统均受到严重影响,并且在找到根源并最终解决问题之前 , 数据库实例往往须要重启 。
3. OPS或RAC中的多个实例或所有实例都Hang住
在这种情况下,即使是OPS或RAC,都已经没办法提供高可用特性了 。使用这个数据库的所有应用系统将不能继续提供服务,这种情况往往须要重启 。
无响应故障成因分析
Oracle数据库无响应,一般主要由以下几种原因引起:
1. 数据库主机负载过高,严重超过主机承受能力
比如应用设计不当 , 数据库性能低下,活动会话数的大量增加,导致数据库主机的负载迅速增加,数据库不能正常操作 , 并最终Hang住;主机物理内存严重不足,引起大量的换页,特别是在SGA中的内存被大量换出到虚拟内存时,数据库实例往往就会Hang住 。
2. 日常维护不当、不正确的操作引起数据库Hang住
比如归档日志的存储空间满 , 导致数据库不能归档,引起数据库Hang住;在一个大并发的繁忙的系
统上,对DML操作比较多的大表进行move、增加外键约束等操作也可能使系统在短时间内负载大幅升高,并引起数据库系统Hang住;不正确的资源计划(Resource Plan)配置 , 使进程得不到足够的CPU等 。
3. Oracle数据库的Bug
几乎每个版本都存在着会导致数据库系统Hang住的Bug,这些Bug会在一些特定的条件下触发,特别是在RAC数据库中,引起数据库Hang住的Bug比较多 。
4. 其他方面的一些原因
比如在RAC数据库中,如果一个节点退出或加入到RAC的过程中,当进行Resource Reconfiguration时,会使系统冻结一段时间 , 也有可能使系统Hang住 。
以上所描述的几种常见的会导致Oracle数据库实例Hang住的原因中,大部分的情况是可以避免的 , 只要维护得当,一般不会出现这种故障 。对于Oracle数据库Bug所导致的数据库无响应故障,由于是在特定的情况下才会触发,所以如果能够尽量对数据库打上最新版本的补?。?并且熟悉当前版本中会导致系统Hang住的Bug以及触发条件 , 就能够最大限度地避免这种故障的发生,提高系统的可用性 。
那么,在数据库Hang住的情况下,如何去分析并发现导致问题的根源?一方面,由于系统Hang住会导致业务系统不可用 , 为了能够尽快地恢复业务,须快速地判断问题所在,然后Kill掉引起故障的会话和进程,或者数据库实例不得不重启以迅速恢复业务;但另一方面,如果只是重启数据库或Kill会话和进程来解决问题 , 在很多情况下是治标不治本的办法,在以后故障随时可能会出现 。如何在二者之间进行抉择呢?对于数据库Hang故障的处理,首先是尽可能地收集到系统Hang住时的状态数据,然后尽快地恢复业务,恢复业务后分析收集到的数据,找到数据库系统Hang住的真正原因 , 然后再进行相应的处理 。下一节将详细描述数据库系统Hang住后的处理流程 。
无响应故障处理流程
对于Oracle无响应故障的处理 , 我们可以按下图所示的流程进行 。
值得注意的是,上图并不是一个完整的Oracle数据库故障处理流程图,只是处理Oralce数据库无响应这一类特定的故障的流程,只列出了针对这一特定类型故障处理时的关键处理点 。不过既然是故障,所以这类故障的处理流程与其他故障的处理流程,有着非常相似的地方 。
下面是整个流程的详细说明:
1. 在出现数据库无响应故障后,首先确认系统的影响范围,如上节所描述的',是部分业务系统或模块还是所有的业务系统都受影响 , 是不是整个实例或多个实例都无响应 。同时应询问系统维护和开发人员,受影响的系统在出现故障前是否有过变动,包括主机硬件、操作系统、网络、数据库以及应用等 。有时一个细小的变动就可能导致出现数据库Hang住这样严重的故障 。曾经遇到一个库,应用只是修改了一个SELECT语句就导致了数据库Hang住 。
2. 为了避免由于网络、数据库监听或客户端因素影响分析,建议都登录到主机上进行操作 。
3. 如果主机不能登录(为了避免干扰流程主线,这里不讨论如网络问题这样也会导致不能连接的故障),尝试关闭出现问题的业务系统 , 甚至是所有的业务系统 。如果关闭了所有的业务系统之后,仍然不能连接,则只有考虑重新启动数据库主机 。在数据库主机重新启动后,使用操作系统工具或OSW等长期监控操作系统的资源使用,同时监控Oracle数据库的性能和等待等 。
4. 登录上主机后,先用top、topas等命令简单观察一下系统 。看看系统的CPU使用、物理内存和虚拟内存的使用、IO使用等情况 。
5. 使用SQLPLUS连接数据库,如果不能连接,则只能从操作系统上观察系统中是否有异常的现象 , 比如占用CPU过高的进程 。使用gdb、dbx等debugger工具对数据库进行system state dump;使用strace、truss等工具检查异常进程的系统调用;使用pstack、procstack等工具察看异常进程的call stack等 。
6. 使用SQLPLUS连接上数据库后,进行hanganalyze、system state dump等操作;或检查等待事件、异常会话等正在执行的SQL等待 。
7. 找到故障产生的原因,如果暂时找不到原因,尽量收集数据 。
8.确良如果应用急须恢复,可通过Kill会话、重启数据库实例等方式,先恢复应用 。
9. 根据最终诊断结果,对数据库升级打补丁,或者修改应用等方式从根本上解决问题 。
怎样避免数据库出现无响应故障
作为Oracle数据库DBA,除了处理故障之外,更重要的是如何预防故障的发生 。根据前面对数据库无响应故障的成因分析,在日常的维护工作中 , 须做到以下几点:
1. 进行正确的维护操作
很多的数据库无响应故障都是由于不正确的维护操作引起的 。应避免在业务高峰期做大的维护操作,比如像move、加主外键约束等会长时间锁表的操作 。如果的确需要,尽量使用正确的操作方法 。比如用ONLINE方式重建索引;建主键、唯一键约束时先建索引,然后在建约束时指定新建的索引,等等 。也就是保证系统的并发性、可伸缩性,避免系统串行操作的出现 。
2. 优化应用设计,优化数据库性能
为避免性能问题导致在业务高峰期数据库不能及时有效处理来自业务的请求 , 甚至于完全Hang住 。对于数据库中存在串行访问的部分进行优化,比如latch、enqueue , 还包括不合理的sequence设计等 。特别是在RAC数据库中,严重串行访问等待往往更容易引起严重的性能问题 。优化应用设计,使数据库具有更好的可伸缩性和并行处理能力,能够有效地避免性能问题引起的数据库Hang住 。
3. 利用监控系统随时监控系统负载
遇到系统负载过高,内存不足,OS中虚拟内存换页很频繁等情况时,及时采取措施;监控Oracle数据库的核心进程,如pmon、smon等 , 看是否有异常,如过高的CPU消耗 。出现异常应立即处理;监控归档空间和日志切换;监控数据库中的等待事件 , 比如是否有大量的enqueue、log file switch (archiving needed)、resmgr:become active等待事件等 。
4. 为数据库打上补丁
很多的无响应故障是由于Oracle的Bug引起的,数据库DBA应关注当前版本中有哪些Bug会导致数据库Hang?。?尽量为数据库打上解决这些Bug的补丁 。
;
数据库紧急救援服务 oracle数据库不明原因宕机,无法启动怎么办?不管是单机、双机热备份(HA系统)、RAC(Oracle
Real
Application)环境如何预防oracle宕机,如果数据库出现异常宕机,并且无法重新启动,那你可能面对如何预防oracle宕机了极为严重的问题 。
检查Oracle的alert文件可能可以获得更为详细的故障信息,当您的技术力量无法判断或解决故障时,可以联系重庆思庄科技协助解决和处理 。
oracle 10g 32位 linux 下最经经常自动宕机,求助修改oratab文件 , 使数据库自动启动
#vi /etc/oratab
sid:/opt/app/ora10g/oracle/product/10.2.0/db_1:Y-----即把原来的N修改为Y 。
oracle数据库服务宕机可能是什么原因造成的?原因很多,内部原因外部原因都有可能 。
外部原因:比如服务器宕机,系统错误,温度过高宕机(比如机房空调坏了) , 临时断电,内存错误等等这些都有可能,电压不足等等 。
内部原因:比较常见的有undo文件损坏 , 数据文件错误(遇到过一次,最后用补0的方法扩大了数据文件才好 , 不过现在用asm存储,这个应该不怎么可能了),时间调整错误(向后调,改动时间过长,比如00:00改为01:00,那么就两个情况都占,未必一定宕机,不过可能性很大),核心进程错误(这个比较少见,不过真的有,有时是有人误杀了) , 程序错误导致(见过一个因为某程序错误,导致锁表,而后锁表导致某进程一直占用内存,后来的进程根本进不了该表 , 然后越滚越大最后宕机,还是后来查出来的,相当于蝴蝶扇翅膀变成飓风,所以有错误要及时发现才行),存储错误,io争用(持续时间长)等等 。
这么说吧,很多的ora错误都可能引起宕机(并不是全部ora错误都会引起宕机),真要说的话要很长时间 , 如果想不宕机那么就要有监测检查制度,早发现早解决,也就不会有什么问题了 。
如何预防oracle宕机的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于如何停止oracle服务、如何预防oracle宕机的信息别忘了在本站进行查找喔 。
推荐阅读
- postgresql建立空间数据库的简单介绍
- 地铁安检拍摄用什么,地铁安检员有什么要求
- 模拟飞机单机游戏,模拟飞机单机游戏手机版
- thinkphp动态路由,实现动态路由
- linux开启log命令 linux logs
- wordpress如何修改语言,wordpress安装完后改中文
- 新品牌洗衣液如何推广销售,新品牌洗衣液如何推广销售的
- 免费制作网页的网站,免费简单网页制作成品
- linux例行性命令 linux 命令执行过程