http://www.akadia.com/services/ora_enable_core.html
Overview
在大多数linux发行版中,普通帐户默认是无法创建core文件的。但是,对于某些应用(比如Oracle)启用这项功能可能非常必要。例如,如果你遇到一个Oracle中的ORA-7445错误,可能就需要Oracle帐户写一个core文件。
启用写core文件功能需要使用 ulimit 命令,在允许如下控制的系统上,它控制被shell启动的进程所能使用的资源。
如果你试图启用写core文件功能,你常常会遇到如下问题。正常情况下是使用SSH登录到服务器上的。
ssh oracle@ora-server
$ ulimit -acore file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
file size (blocks, -f) unlimited
pending signals (-i) 1024
max locked memory (kbytes, -l) 32
max memory size (kbytes, -m) unlimited
open files (-n) 65536
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 16384
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited现在,如果不是root帐户,尝试修改core文件大小为unlimited
$ ulimit -c unlimited
-bash: ulimit: core file size: cannot modify limit: Operation not permitted
Solution
检查ulimit相关的环境变量
第一步是确认你没有在这个帐户的shell设置文件中把core文件大小设为0,即有以下命令 ulimit -c 0,检查$HOME/.bash_profile 或者 $HOME/.bashrc,如果发现 ulimit -c 0 就注释掉它。
#
# Do not produce core dumps
#
# ulimit -c 0 全局启用 Core Dumps这一步必须使用root帐户,通常在 /etc/security/limits.conf中,添加一行
# /etc/security/limits.conf
* soft core unlimited
到文件末尾。
#
# Each line describes a limit for a user in the form:
#
# <domain> <type> <item> <value>
#
* soft core unlimited
- 重新登录然后设置 ulimit
ssh oracle@ora-server
$ ulimit -c
0
先尝试使用root帐户设置 ulimit
su -
ulimit -c unlimited
ulimit -c
unlimited
现在也可以使用oracle帐户来设置 ulimit了Now you can set ulimit also for user oracle
su - oracle
ulimit -c unlimited
ulimit -c
unlimited可能最后的第三步并不总是必要的,但是使用这个流程可以保证每次都成功。core文件的限制通常也在不同的配置文件中设置,如果你希望启用它们,你可以把它们注释掉。
In /etc/profile (Redhat)
# No core files by default
# ulimit -S -c 0 > /dev/null 2>&1In /etc/init.d/functions (Redhat)
# make sure it doesn't core dump anywhere unless requested
# ulimit -S -c ${DAEMON_COREFILE_LIMIT:-0} >/dev/null 2>&1现在从当前shell已经可以产生core文件了,使用ulimit -a 检查下。
$ ulimit -a
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
file size (blocks, -f) unlimited
pending signals (-i) 1024
max locked memory (kbytes, -l) 32
max memory size (kbytes, -m) unlimited
open files (-n) 65536
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 16384
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited