数据库shutdown之后无法启动的问题 (46天)

最近在已有数据库服务器上又新建了4个数据库实例,目前一共有9个数据库实例。环境搭好以后做检查的时候。根据反馈,有个job报如下的错误。

Failed to create connection for url=jdbc:oracle:thin:@xxxxx and dbUser=xxxxxx
Nested Exception/Error: 
java.sql.SQLRecoverableException: IO Error: Got minus one from a read call 
        at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:419) 
        at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:536) 
        at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:228) 

这个问题,根据以往的经验就是process的值太低了。需要调大一些。查看数据库process的值,一看还真是,当时只设置了150,这个job平均要占用100多个session,其他的一些环境加进来,肯定不够。 因为调高process需要重启数据库,和他们协调了下,就开始操作了。 我先把process调到3000,session也相应调整,然后保存在spfile里面。 alter system set processes=3000 scope=spfile; 然后就按照计划开始停库,一个一个重启。 前面的3个很快就做完了,然后到最后一个,还是小心的按照nomount,mount的一步一步来。结果还是出问题了。

SQL> 
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup nomount
ORA-27154: post/wait create failed
ORA-27300: OS system dependent operation:semget failed with status: 28
ORA-27301: OS failure message: No space left on device
ORA-27302: failure occurred at: sskgpcreates
SQL> exit

根据错误信息,是空间问题。但是查看的时候,空间还多着呢。

/dev/vx/dsk/vgusgsPT301/lvol6
                       20G  8.5G   11G  44% /opt/app/oracle/db1
/dev/vx/dsk/vgusgsPT401/lvol6
                       20G  8.5G   11G  44% /opt/app/oracle/db2
/dev/vx/dsk/vgusgsPT501/lvol6
                       20G   11G  8.7G  56% /opt/app/oracle/db3
/dev/vx/dsk/vgusgsPT601/lvol6
  20G   11G  8.7G  56% /opt/app/oracle/db4

用top查看空余内存,也还有不少。

Tasks: 1000 total,   1 running, 999 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.3%us,  0.1%sy,  0.0%ni, 99.5%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  189675188k total, 183821096k used,  5854092k free,   678412k buffers
Swap: 376009348k total,  1892592k used, 374116756k free, 176567228k cached

开始排查是否是kernel引起的。

> /sbin/sysctl -a | grep sem
error: permission denied on key 'kernel.cad_pid'
error: permission denied on key 'kernel.cap-bound'
kernel.sem = 256        32000   100     500

查看sysctl.conf
 > less /etc/sysctl.conf 
# Kernel sysctl configuration file for Red Hat Linux
#
# For binary values, 0 is disabled, 1 is enabled.  See sysctl(8) and
# sysctl.conf(5) for more details.
# Controls IP packet forwarding
net.ipv4.ip_forward = 0
# Controls source route verification
net.ipv4.conf.default.rp_filter = 1
# Do not accept source routing
net.ipv4.conf.default.accept_source_route = 0
# Controls the System Request debugging functionality of the kernel
kernel.sysrq = 0
# Controls whether core dumps will append the PID to the core filename
# Useful for debugging multi-threaded applications
kernel.core_uses_pid = 1
# Controls the use of TCP syncookies
net.ipv4.tcp_syncookies = 1
# Controls the maximum size of a message, in bytes
kernel.msgmnb = 65536
# Controls the default maxmimum size of a mesage queue
kernel.msgmax = 65536
# Controls the maximum shared segment size, in bytes
kernel.shmmax = 68719476736
# Controls the maximum number of shared memory segments, in pages
kernel.shmall = 4294967296
### DBA REQUEST FOR ORACLE11 ###
kernel.shmmni = 4096
kernel.sem = 256 32000 100 500
fs.file-max = 6815744
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_max = 4194394
net.core.wmem_max = 1048576
net.core.rmem_default = 262144
net.core.wmem_default = 262144
fs.aio-max-nr = 3145728

但是查看当前的进程数,也才不到10000,离32000还远呢。 查看了一下其他的库的process情况,终于明白了。 原有的5台,有4台process都是5000,一台是3000,一共就是23000 新加的4台,process都是3000,一共就是12000 加起来还真是超了。也难怪新加的第3个数据库实例没有问题,23000+9000=32000,刚好占完了,一点都没剩下。 和部门协调了一下,原有的5台process平时测试用不了那么多,3000多process已经足够了。 就调整了一下,再次重启就没有问题了。

> sqlplus / as sysdba
SQL*Plus: Release 11.2.0.2.0 Production on Wed Apr 16 15:05:37 2014
Copyright (c) 1982, 2010, Oracle.  All rights reserved.
Connected to an idle instance.
SQL> startup nomount
ORACLE instance started.
Total System Global Area 1.1742E+10 bytes
Fixed Size                  2251264 bytes
Variable Size            5234492928 bytes
Database Buffers         6492782592 bytes
Redo Buffers               12193792 bytes

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-04-18

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏项勇

笔记78 | 解读一个闹钟代码

最近因工作需要做一个定时器,一看需求,深思极恐: 1.定时发送开关指令; 2.可设置周期循环; 这不就是一个标准的闹钟吗? 哎呀,烧脑~

652
来自专栏杨建荣的学习笔记

一条关于swap争用的报警邮件分析(一)(r7笔记第28天)

最近这些天有一台服务器总是会收到剩余swap过低的告警。 邮件内容大体如下: ############ ZABBIX-监控系统: --------------...

3354
来自专栏Micro_awake web

HTML5 Web缓存&运用程序缓存&cookie,session

在介绍HTML5 web缓存前,来认识一下cookie和session: session: 由于HTTP是无状态的,你是谁?你干了什么?抱歉服务器都是不知道的。...

1877
来自专栏睿哥杂货铺

玩转编程语言:基于Node.js构建自定义代码生成器

在真实的软件开发过程中,无论使用何种编程开发语言,都不可避免的会遇到代码重复的问题。如何处理重复的问题,可以选择情怀(手动再敲一遍),也可以选择 Copy-to...

2185
来自专栏Golang语言社区

剖析Go编写的Socket服务器模块解耦及基础模块的设计

Server的解耦—通过Router+Controller实现逻辑分发 在实际的系统项目工程中中,我们在写代码的时候要尽量避免不必要的耦合,否则你以后在更新和维...

3214
来自专栏Golang语言社区

剖析Go编写的Socket服务器模块解耦及基础模块的设计

Server的解耦—通过Router+Controller实现逻辑分发 在实际的系统项目工程中中,我们在写代码的时候要尽量避免不必要的耦合,否则你以后在更新和维...

3428
来自专栏bboysoul

信息收集工具(Th3inspector Tool)安装使用体验

https://github.com/Moham3dRiahi/Th3inspector

813
来自专栏Golang语言社区

剖析Go编写的Socket服务器模块解耦及基础模块的设计

Server的解耦—通过Router+Controller实现逻辑分发 在实际的系统项目工程中中,我们在写代码的时候要尽量避免不必要的耦合,否则你以后在更新和维...

3617
来自专栏一个会写诗的程序员的博客

Ktor: Kotlin Web后端框架 快速开始入门Ktor: Kotlin Web后端框架 Web backend framework for Kotlin 快速开始入门《Kotlin极简教

1072
来自专栏潇涧技术专栏

Head First Android Testing 2

Instrumentation Tests又叫Device or Emulator Tests,即运行在设备或者模拟器上的测试。使用AndroidJunitRu...

572

扫码关注云+社区