rotate.html

来自「java类库详细讲解」· HTML 代码 · 共 145 行

HTML
145
字号
<HTML>
<HEAD>
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
<TITLE>Limiting the Size of a Log by Using a Rotating Sequence of Files
(Java Developers Almanac Example)
</TITLE>
<META CONTENT="Patrick Chan" NAME="AUTHOR">
<META CONTENT="Code Examples from The Java Developers Almanac 1.4" NAME="DESCRIPTION">
<META CONTENT="Addison-Wesley/Patrick Chan" NAME="OWNER">
<META CONTENT="3/20/02" NAME="revision">
<STYLE TYPE="text/css">
<!--     BODY CODE  {font-family: Courier, Monospace;           font-size: 11pt}    TABLE, BODY          {font-family: Verdana, Arial, Helvetica, sans-serif;           font-size: 10pt}    PRE   {font-family: Courier, Monospace;           font-size: 10pt}    H3    {font-family: Verdana, Arial, Helvetica, sans-serif;           font-size: 11pt}    A.eglink {text-decoration: none}    A:hover.eglink {text-decoration: underline}    -->
</STYLE>
</HEAD>
<BODY>
<TABLE CELLSPACING="0" CELLPADDING="0" BORDER="0">
<TR>
<TD rowspan="3"><A HREF="/?l=ex"><IMG BORDER="0" ALIGN="BOTTOM" HSPACE="10" SRC="/egs/almanac14a.jpg"></A></TD><TD VALIGN="top"><font face="Times" size="6"><b>The Java Developers Almanac 1.4</b></font>
<br>
        Order this book from <a href="/cgi-bin/scripts/redirect.pl?l=ex&url=http://www.amazon.com/exec/obidos/ASIN/0201752808/xeo">Amazon</a>.
    </TD>
</TR>
<TR>
<TD align="right" valign="bottom">
<FORM method="get" action="/cgi-bin/search/find.pl">
<INPUT size="25" name="words" type="text"><INPUT value="Search" type="submit">
</FORM>
</TD>
</TR>
</TABLE>
<HR color="#6666cc">
<DIV ALIGN="LEFT">
<A HREF="/">Home</A>
    &gt;
    <A HREF="../index.html">List of Packages</A>
    &gt;
    <B><A HREF="../java.util.logging/pkg.html">java.util.logging</A></B><font color="#666666" SIZE="-2">
        &nbsp;[20 examples]
        </font>
        &gt;
        <B><A HREF="../java.util.logging/pkg.html#File%20Size">File Size</A></B><font color="#666666" SIZE="-2">
            &nbsp;[2 examples]
            </font>
</DIV><P>
  <h3>
    e402.  
    Limiting the Size of a Log by Using a Rotating Sequence of Files</h3>

The example <a href="../java.util.logging/LimitFileSize.html" class="eglink"><font size="-1"><b>e401</b> Limiting the Size of a Log File</font></a> shows how to
limit the log file size by automatically emptying it when it reaches
the limit.  However, this approach has the disadvantage of discarding
useful information even though the file size might be well within the
limit.  The <code>FileHandler</code> allows a more effective approach by allowing
you to use a sequence of files to hold the log information. When a
file fills up, the oldest file is emptied and logging resumes in that
file.

<P> More specifically, if there are <code>N</code> log files in the
sequence, records are always dumped into <code>logfile0</code>. When
<code>logfile0</code> is filled, <code>logfileN-2</code> is renamed to <code>logfileN</code>,
<code>logfileN-3</code> is renamed to <code>logfileN-2</code>, etc. Finally,
<code>logfile0</code> is renamed <code>logfile1</code>. A new <code>logfile0</code> is created
and logging resumes in the new <code>logfile0</code>.  To read the log records
in chronological order, you need to process the files from
<code>logfileN-1</code> to <code>logfile0</code>.

<P> The logfile number is called the generation number and ranges
from 0 to the number of logfiles - 1.  When specifying the filename
pattern to use for the logfiles, you need to include the location of
the generation number using the <code>%g</code> placeholder.  For example,
using a filename pattern of <code>my%g.log</code> with three log files will result
in the files <code>my0.log</code>, <code>my1.log</code>, and <code>my2.log</code>.


<pre>
    try {
        // Create a file handler that uses 3 logfiles, each with a limit of 1Mbyte
        String pattern = <font color="#0066ff"><i>"my%g.log"</i></font>;
        int limit = <font color="#0066ff"><i>1000000</i></font>; // 1 Mb
        int numLogFiles = <font color="#0066ff"><i>3</i></font>;
        FileHandler fh = new FileHandler(pattern, limit, numLogFiles);
    
        // Add to logger
        Logger logger = Logger.getLogger(<font color="#0066ff"><i>"com.mycompany"</i></font>);
        logger.addHandler(fh);
    } catch (IOException e) {
    }
</pre>
<P><table width="600" CELLSPACING="0" CELLPADDING="2" BORDER="0">
<tr>
<td bgcolor="#6666cc" align="center"><font color="#ffffff">
            &nbsp;Related Examples
        </font></td>
</tr>
</table>


e401. <a class="eglink" href="LimitFileSize.html?l=rel">
    Limiting the Size of a Log File
</a>
<br>


<table width="600" CELLSPACING="0" CELLPADDING="2" BORDER="0">
<tr>
<td align="left">
<br>
        See also: 
<a class="eglink" href="/egs/java.util.logging/pkg.html?l=rel#Configuration">
    Configuration
</a>&nbsp;&nbsp;

<a class="eglink" href="/egs/java.util.logging/pkg.html?l=rel#Formatters">
    Formatters
</a>&nbsp;&nbsp;

<a class="eglink" href="/egs/java.util.logging/pkg.html?l=rel#Levels">
    Levels
</a>&nbsp;&nbsp;

</td>
</tr>
</table>

<br>

<br>
<FONT FACE="Verdana, Arial, Helvetica, sans-serif" SIZE="0">
&copy; 2002 Addison-Wesley.
</FONT>
</BODY>
</HTML>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?