阅微 發表於 2023-8-21 00:00:00

Linux下nginx生成日志自动切割的实现方法

<p>
        <strong>Linux下nginx生成日志自动切割的实现方法</strong></p>
<p>
        1、编辑切割日志的 shell 程序,目录自定</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_959929">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash comments">#vi /data/nginx/cut_nginx_log.sh </code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        输入代码:</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_420402">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash preprocessor bold">#!/bin/bash </code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash spaces">             </code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash comments"># This script run at 00:00 </code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash spaces">             </code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash keyword">function</code> <code class="bash plain">cutAccess() </code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash plain">{ </code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="bash spaces">  </code><code class="bash functions">dir</code><code class="bash plain">=$1 </code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="bash spaces">  </code><code class="bash plain">newdir=</code><code class="bash string">"${dir}/$(date -d "</code><code class="bash plain">yesterday</code><code class="bash string">" +"</code><code class="bash plain">%Y</code><code class="bash string">")/$(date -d "</code><code class="bash plain">yesterday</code><code class="bash string">" +"</code><code class="bash plain">%m</code><code class="bash string">")"</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="bash spaces">  </code><code class="bash plain">suffix=$(</code><code class="bash functions">date</code> <code class="bash plain">-d </code><code class="bash string">"yesterday"</code> <code class="bash plain">+</code><code class="bash string">"%Y%m%d"</code><code class="bash plain">) </code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="bash spaces">  </code><code class="bash functions">mkdir</code> <code class="bash plain">-p $newdir </code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="bash spaces">  </code><code class="bash functions">mv</code> <code class="bash plain">${</code><code class="bash functions">dir</code><code class="bash plain">}</code><code class="bash plain">/access</code><code class="bash plain">.log ${newdir}</code><code class="bash plain">/access</code><code class="bash plain">.$suffix.log </code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="bash plain">} </code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="bash spaces">             </code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="bash plain">cutAccess </code><code class="bash string">"/home/wwwlogs/www.yourdomain.com/"</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="bash plain">cutAccess </code><code class="bash string">"/home/wwwlogs/www.yourdomain-1.com/"</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                        <code class="bash plain">cutAccess </code><code class="bash string">"/home/wwwlogs/www.yourdomain-2.com/"</code>
</div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="bash spaces">           </code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="bash comments"># 重启 nginx </code>
</div>
                                                                <div class="line number19 index18 alt2">
                                                                        <code class="bash functions">kill</code> <code class="bash plain">-HUP `</code><code class="bash functions">cat</code> <code class="bash plain">/usr/local/nginx/logs/nginx</code><code class="bash plain">.pid` </code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        2、加入定时任务,每天0点自动切割</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_497089">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash comments"># crontab -e </code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash plain">0 0 * * * </code><code class="bash plain">/bin/bash</code> <code class="bash plain">/data/nginx/cut_nginx_log</code><code class="bash plain">.sh</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        3、nginx 日志格式</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_520614">
                        <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="bash plain">log_format access </code><code class="bash string">'$remote_addr - $remote_user [$time_local] "$request" '</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash spaces">      </code><code class="bash string">'$status $body_bytes_sent "$http_referer" '</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash spaces">      </code><code class="bash string">'"$http_user_agent" $http_x_forwarded_for'</code><code class="bash plain">; </code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash plain">access_log </code><code class="bash plain">/home/wwwlogs/www</code><code class="bash plain">.yourdomain.com</code><code class="bash plain">/access</code><code class="bash plain">.log access; </code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!</p>
<p>
        原文链接:http://blog.csdn.net/zhouzme/article/details/18909185</p>
頁: [1]
查看完整版本: Linux下nginx生成日志自动切割的实现方法