测试库运行startup当系统提示(11.2.0.1):

查询ORA-27154的错误

Error:  ORA-27154
Text: post/wait create failed
---------------------------------------------------------------------------
Cause: internal error, multiple post/wait creates attempted simultaneously
Action: check errno and contact Oracle Support

提示是一个内部错误,多个post/wait同一时候请求。

df查看磁盘空间还有非常多。不存在占满的情况

查看报错中的semget含义

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmlzYWw=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

提示segmet的含义是get a semaphore set identifier,即获取一个信号量集标识符。说明此错误可能和未获得信号量有关,No
space left on device不是指存储空间,而是指信号量资源。

从MOS的介绍看(949468.1),一系列的报错出现10.1.0.2到11.2.0.2的范围内。给出了演示样例:

$ ipcs -ls

------ Semaphore Limits --------

max number of arrays = 128

max semaphores per array = 250

max semaphores system wide = 32000

max ops per semop call = 100

semaphore max value = 32767

产生的原因是,从原理上看。32000信号量可用。一个信号量标识符能包括最大250个信号量。可是ipcs命令展示每一个信号量标识符仅能让Oracle包括最大156个信号量。

$ ipcs <<
这个演示样例中没有启动额外实例的前提下,大约包括100个信号量字符集

..

------ Semaphore Arrays --------

key semid owner perms nsems

0x450e15bd 0 root 666 1

0x0000cace 32769 root 666 1

0x358b172c 327683 oracle 660 104

0x9053d038 11075588 oracle 660 156

0x9053d039 11108357 oracle 660 156

0x9053d03a 11141126 oracle 660 156

0x9053d03b 11173895 oracle 660 156

..

那么可用的最大信号量就是156*128=19968。不是32000。

解决方法添加可包括的信号量,这里依据SEMMNI參数来调整设置。

1.
查询当前kernel的信号量參数值。

#
/sbin/sysctl -a | grep sem

2.
改动/etc/sysctl.conf文件的SEMMNI參数。

从kernel.sem
= 250 32000 100 128改动为kernel.sem
= 250 32000 100 200

3.
使用# /sbin/sysctl -p让改动生效。

结合到我这里的情况。首先查看ipcs的结果:

数据库启动后。须要从操作系统上分配共享内存和信号量。信号量就相当于OS的内存锁,类似于Oracle的latch(注意Oracle的锁和latch的差别)。每一个进程须要获取操作系统内存时,须要先获得信号量才干申请内存。

从上述指令能够看到最大可用的信号量是100。信号量标识符集最大是128,呃,这里失误,当时没有查看到ipcs实际的信号量标识符集。

这里4个參数的含义:

SEMMSL         100        Defines the minimum recommended value,for initial installation only

The maximum number of sempahores that can be in one semaphore set. It should be same size as maximum number of Oracle processes.

一个信号量集中同意的最大信号量数。须要和Oracle的process个数同样。

SEMMNS        100         Defines the maximum semaphores on the system.

This setting is a minimum recommended value, for initial installation only. The SEMMNS parameter should be set to the sum of the PROCESSES parameterfor each Oracle database, adding the largest
one twice, and then adding an additional 10 for each database.

系统同意的最大信号量数。SEMMNS參数应设置为最大的PROCESSES值,再加上额外的10,算出来的总和。(注意这里说明该值是最小的建议值)

SEMOPM        32         
Defines the maximum number of operations for each semop call

每次信号量调用的最大操作数。

SEMMNI        128         Defines the maximum number of semaphore sets in the entire system

系统中信号量集的最大值。

能够猜測SEMMNS=SEMMSL * SEMMNI。

但上述演示样例中:100<>100 * 128。SEMMNS最大同意的信号量(建议最小值)仅仅有100。显然不能满足计算结果的数量。

并且从Oracle官方文档看到的对于这几个參数的推荐值

Configuring Kernel Parameters

Verify that the kernel parameters shown in the following table are set to values greater than or equal to the recommended value shown. The procedure following the table describes how to verify and set the values.

Parameter Value File
semmsl

semmns

semopm

semmni

250

32000

100

128

/proc/sys/kernel/sem

SEMMNS是32000。即SEMMSI(250)*SEMMNI(128)的结果。

进而能够判断报错提示的sskgpcreates可能和process数量有关,kernel中和该值有关的參数是SEMMNS,和上述猜測的结论同样。即PROCESS过多,但同意的最大信号量过少。两者不匹配,导致No
space left on device提示信号量资源不足

解决方法如MOS指点的。改动信号量參数值,能够用:

这样的方式仅仅是暂时改动,机器重新启动后失效。若须要持久生效,能够改动/etc/sysctl.conf相应的參数值。

总结

1. 错误提示No
space left on device未必表示存储空间不足,本例中就是指的信号量资源。

2. kernel.sem中四个參数的含义,以及SEMMNS(同意的最大信号量)=SEMMSL(一个信号量集同意包括的信号量)
* SEMMNI(系统同意包括的最大信号量集)的计算关系。还有就是SEMMNS定义的是Defines
the maximum semaphores on the system. This setting is a minimum recommended value,for initial installation only. 即同意的最大信号量,但这个值是用于初始安装的最小推荐值。

3.
借助baidu或google甚至MOS查找问题,可能找到解决方式,但更重要的是可以知道原因。进而了解问题出现的场景。结合自己的问题。确定是同一类之后,再运行操作,一句话:要慎重。

版权声明:本文博主原创文章。博客,未经同意不得转载。

由于问题引起信号ORA-27154无法启动数据库的更多相关文章

  1. Linux 启动数据库报错:could not open parameter file init**.ora

    sqlplus /nolog.conn /as sysdba.startup命令后显示 SQL> startupORA-01078: failure in processing system p ...

  2. Oracle 通过sqlnet.ora文件控制对Oracle数据库的访问

    一.通过sqlnet.ora文件控制对Oracle数据库的访问 出于数据安全考虑,对Oracle数据库的IP做一些限制,只有固定的IP才能访问.修改$JAVA_HOME/NETWORK/ADMIN/s ...

  3. oracle在cmd中启动数据库实例

    在cmd中启动数据库实例: sqlplus /nolog 回车, conn as sysdba;回车,startup;然后回车

  4. sqlserver如何启动数据库邮件

    可以在 msdb 数据库中停止数据库邮件.若要检查数据库邮件的状态,请执行下面的语句: 复制 EXECUTE dbo.sysmail_help_status_sp; 若要在邮件主机数据库中启动数据库邮 ...

  5. hsql使用架构包启动数据库

    一.通常我们平时启动就是直接通过hsql.jar来进行启动 java -cp hsqldb.jar org.hsqldb.util.DatabaseManagerSwing java -cp hsql ...

  6. Oracle11g 启动数据库实例、关闭数据库实例

    Oracle11g 启动数据库实例        startup 1: nomount 模式:      描述:             该模式只会创建实例(即:创建oracle 实例的各种内存结构和 ...

  7. linux环境:创建数据库用户,表空间,启动数据库

    1.启动数据库 首先使用oracle用户登录Linux,然后在shell命令行中执行下面的命令:第一步:打开Oracle监听(先查看状态:oracle监听是否启动:lsnrctl status)$ l ...

  8. linux环境启动数据库

    1.查看数据库监听的状态: 监听状态:lsnrctl status  出现如下列截图所示数据,说明切切换账户有问题:切换账户时要家:-:  如 su - oracle 第一步:打开Oracle监听$ ...

  9. 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库

    第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1.  学习方法 2.  多涨见识 3.  比自己强的人一起,学习更强:比自己更聪明的人 ...

  10. oracle 启动数据库与监听器

    1.oracle 启动数据库与监听器 1)启动数据库 oracle用户进去 oracle/oracle sqlplus / as sysdba 然后startup 退出,然后启动监听进程 2)启动监听 ...

随机推荐

  1. 得到View Frustum的6飞机

    笔者:i_dovelemon 资源:CSDN 日期:2014 / 9 / 30 主题:View Frustum, Plane, View Matrix, Perspective Projection ...

  2. 【转】c#实现字符串倒序的n种写法

    其中LINQ写法最为简洁 //string concatenation with for loop public string ReverseA(string text) {     char[] c ...

  3. 让你提前认识软件开发(17):makefile文件的书写及应用

    第1部分 又一次认识C语言 makefile文件的书写及应用 [文章摘要] makefile用于Linux下整个project的编译.对于Linux下的C/C++语言的编译是至关重要的. 本文以实际的 ...

  4. ios 多线程开发(三)Run Loops

    Run loops是线程相关的一些基本东西.一个run loop是一个处理消息的循环.用来处理计划任务或者收到的事件.run loop的作用是在有事做的时候保持线程繁忙,没事的时候让线程挂起. Run ...

  5. 重写TextBox实现显示提示信息

    /// <summary> /// TextBox提示信息 /// </summary> /// <author>Tim_et</author> /// ...

  6. head first c&lt;11&gt;在根据网络编程

    博文可以在一个大的网络通信实现,但是,一个人只能起到,我们能够给每个clientfork()子进程,实现诸多的服务. 方法: client连到server以后,server启动一个新创建的套接字对话. ...

  7. Jeditable 点击编辑文字插件

    Jeditable - jQuery就地编辑插件使用   jeditable是一个jquery插件,它的优点是可以就地编辑,并且提交到服务器处理,是一个不可多得的就地编辑插件.(注: 就地编辑,也有称 ...

  8. 用python做自己主动化測试--对server端的自己主动化測试(3)-很多其它http client实例

    上一篇中仅仅是实现了一个非常easy的http client功能,request还提供了keep alive, SSL, 多文件上传,cookie 管理功能,http requests头管理等丰富的功 ...

  9. 【七】注入框架RoboGuice使用:(Your First Custom Binding)

    上一篇我们简单的介绍了一下RoboGuice的使用([六]注入框架RoboGuice使用:(Singletons And ContextSingletons)),今天我们来看下自己定义绑定(bindi ...

  10. Git--Submodule使用

    项目模板中通常由前端保持,所以每次更新模板.我也要跟着变化项目. 随着时间的推移,这不是一个方法来找到,老这么维护.大型项目,更多的模板,真的很容易管理和维护. 然后头让我用submodule前端资源 ...