core文件截斷的處理方法

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 -a

core 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

  1. 檢查ulimit相關的環境變量
    第一步是確認你沒有在這個帳戶的shell設置文件中把core文件大小設爲0,即有以下命令 ulimit -c 0,檢查$HOME/.bash_profile 或者 $HOME/.bashrc,如果發現 ulimit -c 0 就註釋掉它。
    #
    # Do not produce core dumps
    #
    # ulimit -c 0

  2. 全局啓用 Core Dumps

    這一步必須使用root帳戶,通常在 /etc/security/limits.conf中,添加一行
    soft  core  unlimited
    到文件末尾。

    # /etc/security/limits.conf
    #
    #
     Each line describes a limit for a user in the form:
    #
    #
     <domain> <type> <item> <value>
    #

    *  soft  core  unlimited

     
  3. 重新登錄然後設置 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>&1

In /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


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章