周总说 發表於 2023-12-29 00:00:00

CentOS 7中Nginx日志定时拆分实现过程详解

<p>
        <strong>一、编写拆分脚本(splitNginxLog.sh)</strong></p>
<p>
        * 因为本例中设置每天0点进行日志的拆分,所以folder和rq均设置采用昨天的日期进行归档。</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_490692">
                        <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>
                                                </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 plain">folder=`</code><code class="bash functions">date</code> <code class="bash plain">-d yesterday +%Y%m`</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash plain">rq=`</code><code class="bash functions">date</code> <code class="bash plain">-d yesterday +%Y%m%d`</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash comments"># 原始日志路径</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash plain">logs_path=</code><code class="bash string">"/var/log/nginx/sitename.com/"</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash comments"># 日志备份路径</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="bash plain">logs_backup_path=</code><code class="bash string">"/var/log/nginx/sitename.com/$folder"</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="bash comments"># 要分割的日志</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="bash plain">logs_access=</code><code class="bash string">"access"</code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="bash plain">logs_error=</code><code class="bash string">"error"</code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="bash comments"># 创建备份路径</code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="bash plain">[ -d $logs_backup_path ]||</code><code class="bash functions">mkdir</code> <code class="bash plain">-p $logs_backup_path</code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="bash comments"># 将日志移入备份文件夹</code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="bash functions">mv</code> <code class="bash plain">${logs_path}${logs_access}.log ${logs_backup_path}/${logs_access}_${rq}.log</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="bash functions">mv</code> <code class="bash plain">${logs_path}${logs_error}.log ${logs_backup_path}/${logs_error}_${rq}.log</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                        <code class="bash comments"># 终止nginx的pid</code>
</div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="bash plain">pid_path=</code><code class="bash string">"/var/run/nginx.pid"</code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="bash functions">kill</code> <code class="bash plain">-USR1 $(</code><code class="bash functions">cat</code> <code class="bash plain">$pid_path)</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong>二、测试日志拆分脚本</strong></p>
<p>
        在.sh文件的存放目录下运行如下语句,测试拆分脚本是否成功。</p>
<p>
        <code># sh splitNginxLog.sh</code></p>
<p>
        如果提示$'\r': 未找到命令的解决,则有可能是.sh文件编码问题,是因为在Windows编辑器中编写的脚本与在linux中的有一些区别。</p>
<p>
        处理方法:</p>
<p>
        1. 安装dos2unix用于转化编码</p>
<p>
        <code># yum install dos2unix</code>  </p>
<p>
        2. 转换编码</p>
<p>
        <code># dos2unix splitNginx.sh</code>  </p>
<p>
        三、设置定时自动执行</p>
<blockquote>
        <p>
                # crontab -l //列出所有的定时任务<br>
                # crontab -e //编辑定时任务</p>
</blockquote>
<p>
        在其中编写如下语句:</p>
<p>
        <code>00 00 * * * bash /root/splitNginxLog.sh</code></p>
<p>
        以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。</p>
<p>
        原文链接:https://www.cnblogs.com/yangjisen/p/12811711.html</p>
頁: [1]
查看完整版本: CentOS 7中Nginx日志定时拆分实现过程详解