花若开 發表於 2024-2-2 00:00:00

关于linux下core dump【总结】

<p>
        <span><strong>1、前言 </strong></span></p>
<p>
        一直在从事linux下后台开发,经常与core文件打交道。还记得刚开始从事linux下开发时,程序突然崩溃了,也没有任何日志。我不知所措,同事叫我看看core,我却问什么是core,怎么看。同事鄙视的眼神,我依然在目。后来学会了从core文件中分析原因,通过gdb看出程序挂再哪里,分析前后的变量,找出问题的原因。当时就觉得很神奇,core文件是怎么产生的呢?难道系统会自动产生,可是我在自己的linux系统上面写个非法程序测试,并没有产生core问题?这又是怎么回事呢?今天在ngnix的源码时候,发现可以在程序中设置core dump,又是怎么回事呢?在公司发现生成的core文件都带有进程名称、进程id、和时间,这又是怎么做到的呢?今天带着这些疑问来说说core文件是如何生成,如何配置。</p>
<p>
        <span><strong>2、基本概念</strong></span></p>
<p>
        当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做core dump(中文有的翻译成“核心转储”)。我们可以认为 core dump 是“内存快照”,但实际上,除了内存信息之外,还有些关键的程序运行状态也会同时 dump 下来,例如寄存器信息(包括程序指针、栈指针等)、内存管理信息、其他处理器和操作系统状态和信息。core dump 对于编程人员诊断和调试程序是非常有帮助的,因为对于有些程序错误是很难重现的,例如指针异常,而 core dump 文件可以再现程序出错时的情景。</p>
<p>
        <span><strong>3、开启core dump</strong></span></p>
<p>
        可以使用命令ulimit开启,也可以在程序中通过setrlimit系统调用开启。</p>
<p>
        <img title="关于linux下core dump【总结】" alt="关于linux下core dump【总结】" src="https://zhuji.jb51.net/uploads/img/202305/85112eb602c215d868b545c5e170dca4.jpg"></p>
<p>
         </p>
<p>
         </p>
<p>
         </p>
<p>
        程序中开启core dump,通过如下api可以查看和设置rlimit_core</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxhtml" id="highlighter_317657">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xhtml plain">#include &lt;</code><code class="xhtml keyword">sys</code><code class="xhtml plain">/resource.h&gt;</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                         </div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xhtml plain">int getrlimit(int resource, struct rlimit *rlim);</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xhtml plain">int setrlimit(int resource, const struct rlimit *rlim);</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
</div>
<p>
         </p>
<p>
        <strong>参考程序如下所示:</strong></p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxhtml" id="highlighter_523817">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                        <div class="line number5 index4 alt2">
                                                                5</div>
                                                        <div class="line number6 index5 alt1">
                                                                6</div>
                                                        <div class="line number7 index6 alt2">
                                                                7</div>
                                                        <div class="line number8 index7 alt1">
                                                                8</div>
                                                        <div class="line number9 index8 alt2">
                                                                9</div>
                                                        <div class="line number10 index9 alt1">
                                                                10</div>
                                                        <div class="line number11 index10 alt2">
                                                                11</div>
                                                        <div class="line number12 index11 alt1">
                                                                12</div>
                                                        <div class="line number13 index12 alt2">
                                                                13</div>
                                                        <div class="line number14 index13 alt1">
                                                                14</div>
                                                        <div class="line number15 index14 alt2">
                                                                15</div>
                                                        <div class="line number16 index15 alt1">
                                                                16</div>
                                                        <div class="line number17 index16 alt2">
                                                                17</div>
                                                        <div class="line number18 index17 alt1">
                                                                18</div>
                                                        <div class="line number19 index18 alt2">
                                                                19</div>
                                                        <div class="line number20 index19 alt1">
                                                                20</div>
                                                        <div class="line number21 index20 alt2">
                                                                21</div>
                                                        <div class="line number22 index21 alt1">
                                                                22</div>
                                                        <div class="line number23 index22 alt2">
                                                                23</div>
                                                        <div class="line number24 index23 alt1">
                                                                24</div>
                                                        <div class="line number25 index24 alt2">
                                                                25</div>
                                                        <div class="line number26 index25 alt1">
                                                                26</div>
                                                        <div class="line number27 index26 alt2">
                                                                27</div>
                                                        <div class="line number28 index27 alt1">
                                                                28</div>
                                                        <div class="line number29 index28 alt2">
                                                                29</div>
                                                        <div class="line number30 index29 alt1">
                                                                30</div>
                                                        <div class="line number31 index30 alt2">
                                                                31</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xhtml plain">#include &lt;</code><code class="xhtml keyword">unistd.h</code><code class="xhtml plain">&gt;</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xhtml plain">#include &lt;</code><code class="xhtml keyword">sys</code><code class="xhtml plain">/time.h&gt;</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xhtml plain">#include &lt;</code><code class="xhtml keyword">sys</code><code class="xhtml plain">/resource.h&gt;</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xhtml plain">#include &lt;</code><code class="xhtml keyword">stdio.h</code><code class="xhtml plain">&gt;</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="xhtml plain">#define core_size  1024 * 1024 * 500</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="xhtml plain">int main()</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="xhtml plain">{</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">struct rlimit rlmt;</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">if (getrlimit(rlimit_core, &amp;rlmt) == -1) {</code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="xhtml spaces">    </code><code class="xhtml plain">return -1; </code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">}  </code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">printf("before set rlimit core dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);</code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                         </div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">rlmt.rlim_cur = (rlim_t)core_size;</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">rlmt.rlim_max = (rlim_t)core_size;</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                         </div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">if (setrlimit(rlimit_core, &amp;rlmt) == -1) {</code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="xhtml spaces">    </code><code class="xhtml plain">return -1; </code>
</div>
                                                                <div class="line number19 index18 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">}  </code>
</div>
                                                                <div class="line number20 index19 alt1">
                                                                         </div>
                                                                <div class="line number21 index20 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">if (getrlimit(rlimit_core, &amp;rlmt) == -1) {</code>
</div>
                                                                <div class="line number22 index21 alt1">
                                                                        <code class="xhtml spaces">    </code><code class="xhtml plain">return -1; </code>
</div>
                                                                <div class="line number23 index22 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">}  </code>
</div>
                                                                <div class="line number24 index23 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">printf("after set rlimit core dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);</code>
</div>
                                                                <div class="line number25 index24 alt2">
                                                                         </div>
                                                                <div class="line number26 index25 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">/*测试非法内存,产生core文件*/</code>
</div>
                                                                <div class="line number27 index26 alt2">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">int *ptr = null;</code>
</div>
                                                                <div class="line number28 index27 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">*ptr = 10; </code>
</div>
                                                                <div class="line number29 index28 alt2">
                                                                         </div>
                                                                <div class="line number30 index29 alt1">
                                                                        <code class="xhtml spaces">  </code><code class="xhtml plain">return 0;</code>
</div>
                                                                <div class="line number31 index30 alt2">
                                                                        <code class="xhtml plain">}</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
</div>
<p>
        执行./main, 生成的core文件如下所示</p>
<p>
        <img title="关于linux下core dump【总结】" alt="关于linux下core dump【总结】" src="https://zhuji.jb51.net/uploads/img/202305/65cc1d7c6436ba103d204d8e3ede76ab.jpg"></p>
<p>
        gdb调试core文件,查看程序挂在位置。当core dump 之后,使用命令<span> <strong><font color="#000000" face="nsimsun">gdb program core</font></strong></span> 来查看 core 文件,其中 program 为可执行程序名,core 为生成的 core 文件名。</p>
<p>
        <img title="关于linux下core dump【总结】" alt="关于linux下core dump【总结】" src="https://zhuji.jb51.net/uploads/img/202305/9c468264c4733483869693724aabda7c.jpg"></p>
<p>
        以上这篇关于linux下core dump【总结】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。</p>
頁: [1]
查看完整版本: 关于linux下core dump【总结】