亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dailyrollingfileappender.java

?? apache的log4j源碼
?? JAVA
字號:
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at *  *      http://www.apache.org/licenses/LICENSE-2.0 *  * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.log4j;import java.io.IOException;import java.io.File;import java.text.SimpleDateFormat;import java.util.Date;import java.util.GregorianCalendar;import java.util.Calendar;import java.util.TimeZone;import java.util.Locale;import org.apache.log4j.helpers.LogLog;import org.apache.log4j.spi.LoggingEvent;/**   DailyRollingFileAppender extends {@link FileAppender} so that the   underlying file is rolled over at a user chosen frequency.   <p>The rolling schedule is specified by the <b>DatePattern</b>   option. This pattern should follow the {@link SimpleDateFormat}   conventions. In particular, you <em>must</em> escape literal text   within a pair of single quotes. A formatted version of the date   pattern is used as the suffix for the rolled file name.   <p>For example, if the <b>File</b> option is set to   <code>/foo/bar.log</code> and the <b>DatePattern</b> set to   <code>'.'yyyy-MM-dd</code>, on 2001-02-16 at midnight, the logging   file <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2001-02-16</code> and logging for 2001-02-17   will continue in <code>/foo/bar.log</code> until it rolls over   the next day.   <p>Is is possible to specify monthly, weekly, half-daily, daily,   hourly, or minutely rollover schedules.   <p><table border="1" cellpadding="2">   <tr>   <th>DatePattern</th>   <th>Rollover schedule</th>   <th>Example</th>   <tr>   <td><code>'.'yyyy-MM</code>   <td>Rollover at the beginning of each month</td>   <td>At midnight of May 31st, 2002 <code>/foo/bar.log</code> will be   copied to <code>/foo/bar.log.2002-05</code>. Logging for the month   of June will be output to <code>/foo/bar.log</code> until it is   also rolled over the next month.   <tr>   <td><code>'.'yyyy-ww</code>   <td>Rollover at the first day of each week. The first day of the   week depends on the locale.</td>   <td>Assuming the first day of the week is Sunday, on Saturday   midnight, June 9th 2002, the file <i>/foo/bar.log</i> will be   copied to <i>/foo/bar.log.2002-23</i>.  Logging for the 24th week   of 2002 will be output to <code>/foo/bar.log</code> until it is   rolled over the next week.   <tr>   <td><code>'.'yyyy-MM-dd</code>   <td>Rollover at midnight each day.</td>   <td>At midnight, on March 8th, 2002, <code>/foo/bar.log</code> will   be copied to <code>/foo/bar.log.2002-03-08</code>. Logging for the   9th day of March will be output to <code>/foo/bar.log</code> until   it is rolled over the next day.   <tr>   <td><code>'.'yyyy-MM-dd-a</code>   <td>Rollover at midnight and midday of each day.</td>   <td>At noon, on March 9th, 2002, <code>/foo/bar.log</code> will be   copied to <code>/foo/bar.log.2002-03-09-AM</code>. Logging for the   afternoon of the 9th will be output to <code>/foo/bar.log</code>   until it is rolled over at midnight.   <tr>   <td><code>'.'yyyy-MM-dd-HH</code>   <td>Rollover at the top of every hour.</td>   <td>At approximately 11:00.000 o'clock on March 9th, 2002,   <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2002-03-09-10</code>. Logging for the 11th hour   of the 9th of March will be output to <code>/foo/bar.log</code>   until it is rolled over at the beginning of the next hour.   <tr>   <td><code>'.'yyyy-MM-dd-HH-mm</code>   <td>Rollover at the beginning of every minute.</td>   <td>At approximately 11:23,000, on March 9th, 2001,   <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2001-03-09-10-22</code>. Logging for the minute   of 11:23 (9th of March) will be output to   <code>/foo/bar.log</code> until it is rolled over the next minute.   </table>   <p>Do not use the colon ":" character in anywhere in the   <b>DatePattern</b> option. The text before the colon is interpeted   as the protocol specificaion of a URL which is probably not what   you want.   @author Eirik Lygre   @author Ceki G&uuml;lc&uuml; */public class DailyRollingFileAppender extends FileAppender {  // The code assumes that the following constants are in a increasing  // sequence.  static final int TOP_OF_TROUBLE=-1;  static final int TOP_OF_MINUTE = 0;  static final int TOP_OF_HOUR   = 1;  static final int HALF_DAY      = 2;  static final int TOP_OF_DAY    = 3;  static final int TOP_OF_WEEK   = 4;  static final int TOP_OF_MONTH  = 5;  /**     The date pattern. By default, the pattern is set to     "'.'yyyy-MM-dd" meaning daily rollover.   */  private String datePattern = "'.'yyyy-MM-dd";  /**     The log file will be renamed to the value of the     scheduledFilename variable when the next interval is entered. For     example, if the rollover period is one hour, the log file will be     renamed to the value of "scheduledFilename" at the beginning of     the next hour.      The precise time when a rollover occurs depends on logging     activity.   */  private String scheduledFilename;  /**     The next time we estimate a rollover should occur. */  private long nextCheck = System.currentTimeMillis () - 1;  Date now = new Date();  SimpleDateFormat sdf;  RollingCalendar rc = new RollingCalendar();  int checkPeriod = TOP_OF_TROUBLE;  // The gmtTimeZone is used only in computeCheckPeriod() method.  static final TimeZone gmtTimeZone = TimeZone.getTimeZone("GMT");  /**     The default constructor does nothing. */  public DailyRollingFileAppender() {  }  /**    Instantiate a <code>DailyRollingFileAppender</code> and open the    file designated by <code>filename</code>. The opened filename will    become the ouput destination for this appender.    */  public DailyRollingFileAppender (Layout layout, String filename,				   String datePattern) throws IOException {    super(layout, filename, true);    this.datePattern = datePattern;    activateOptions();  }  /**     The <b>DatePattern</b> takes a string in the same format as     expected by {@link SimpleDateFormat}. This options determines the     rollover schedule.   */  public void setDatePattern(String pattern) {    datePattern = pattern;  }  /** Returns the value of the <b>DatePattern</b> option. */  public String getDatePattern() {    return datePattern;  }  public void activateOptions() {    super.activateOptions();    if(datePattern != null && fileName != null) {      now.setTime(System.currentTimeMillis());      sdf = new SimpleDateFormat(datePattern);      int type = computeCheckPeriod();      printPeriodicity(type);      rc.setType(type);      File file = new File(fileName);      scheduledFilename = fileName+sdf.format(new Date(file.lastModified()));    } else {      LogLog.error("Either File or DatePattern options are not set for appender ["		   +name+"].");    }  }  void printPeriodicity(int type) {    switch(type) {    case TOP_OF_MINUTE:      LogLog.debug("Appender ["+name+"] to be rolled every minute.");      break;    case TOP_OF_HOUR:      LogLog.debug("Appender ["+name		   +"] to be rolled on top of every hour.");      break;    case HALF_DAY:      LogLog.debug("Appender ["+name		   +"] to be rolled at midday and midnight.");      break;    case TOP_OF_DAY:      LogLog.debug("Appender ["+name		   +"] to be rolled at midnight.");      break;    case TOP_OF_WEEK:      LogLog.debug("Appender ["+name		   +"] to be rolled at start of week.");      break;    case TOP_OF_MONTH:      LogLog.debug("Appender ["+name		   +"] to be rolled at start of every month.");      break;    default:      LogLog.warn("Unknown periodicity for appender ["+name+"].");    }  }  // This method computes the roll over period by looping over the  // periods, starting with the shortest, and stopping when the r0 is  // different from from r1, where r0 is the epoch formatted according  // the datePattern (supplied by the user) and r1 is the  // epoch+nextMillis(i) formatted according to datePattern. All date  // formatting is done in GMT and not local format because the test  // logic is based on comparisons relative to 1970-01-01 00:00:00  // GMT (the epoch).  int computeCheckPeriod() {    RollingCalendar rollingCalendar = new RollingCalendar(gmtTimeZone, Locale.ENGLISH);    // set sate to 1970-01-01 00:00:00 GMT    Date epoch = new Date(0);    if(datePattern != null) {      for(int i = TOP_OF_MINUTE; i <= TOP_OF_MONTH; i++) {	SimpleDateFormat simpleDateFormat = new SimpleDateFormat(datePattern);	simpleDateFormat.setTimeZone(gmtTimeZone); // do all date formatting in GMT	String r0 = simpleDateFormat.format(epoch);	rollingCalendar.setType(i);	Date next = new Date(rollingCalendar.getNextCheckMillis(epoch));	String r1 =  simpleDateFormat.format(next);	//System.out.println("Type = "+i+", r0 = "+r0+", r1 = "+r1);	if(r0 != null && r1 != null && !r0.equals(r1)) {	  return i;	}      }    }    return TOP_OF_TROUBLE; // Deliberately head for trouble...  }  /**     Rollover the current file to a new file.  */  void rollOver() throws IOException {    /* Compute filename, but only if datePattern is specified */    if (datePattern == null) {      errorHandler.error("Missing DatePattern option in rollOver().");      return;    }    String datedFilename = fileName+sdf.format(now);    // It is too early to roll over because we are still within the    // bounds of the current interval. Rollover will occur once the    // next interval is reached.    if (scheduledFilename.equals(datedFilename)) {      return;    }    // close current file, and rename it to datedFilename    this.closeFile();    File target  = new File(scheduledFilename);    if (target.exists()) {      target.delete();    }    File file = new File(fileName);    boolean result = file.renameTo(target);    if(result) {      LogLog.debug(fileName +" -> "+ scheduledFilename);    } else {      LogLog.error("Failed to rename ["+fileName+"] to ["+scheduledFilename+"].");    }    try {      // This will also close the file. This is OK since multiple      // close operations are safe.      this.setFile(fileName, false, this.bufferedIO, this.bufferSize);    }    catch(IOException e) {      errorHandler.error("setFile("+fileName+", false) call failed.");    }    scheduledFilename = datedFilename;  }  /**   * This method differentiates DailyRollingFileAppender from its   * super class.   *   * <p>Before actually logging, this method will check whether it is   * time to do a rollover. If it is, it will schedule the next   * rollover time and then rollover.   * */  protected void subAppend(LoggingEvent event) {    long n = System.currentTimeMillis();    if (n >= nextCheck) {      now.setTime(n);      nextCheck = rc.getNextCheckMillis(now);      try {	rollOver();      }      catch(IOException ioe) {	LogLog.error("rollOver() failed.", ioe);      }    }    super.subAppend(event);   }}/** *  RollingCalendar is a helper class to DailyRollingFileAppender. *  Given a periodicity type and the current time, it computes the *  start of the next interval.   * */class RollingCalendar extends GregorianCalendar {  private static final long serialVersionUID = -3560331770601814177L;  int type = DailyRollingFileAppender.TOP_OF_TROUBLE;  RollingCalendar() {    super();  }    RollingCalendar(TimeZone tz, Locale locale) {    super(tz, locale);  }    void setType(int type) {    this.type = type;  }  public long getNextCheckMillis(Date now) {    return getNextCheckDate(now).getTime();  }  public Date getNextCheckDate(Date now) {    this.setTime(now);    switch(type) {    case DailyRollingFileAppender.TOP_OF_MINUTE:	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.MINUTE, 1);	break;    case DailyRollingFileAppender.TOP_OF_HOUR:	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.HOUR_OF_DAY, 1);	break;    case DailyRollingFileAppender.HALF_DAY:	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	int hour = get(Calendar.HOUR_OF_DAY);	if(hour < 12) {	  this.set(Calendar.HOUR_OF_DAY, 12);	} else {	  this.set(Calendar.HOUR_OF_DAY, 0);	  this.add(Calendar.DAY_OF_MONTH, 1);	}	break;    case DailyRollingFileAppender.TOP_OF_DAY:	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.DATE, 1);	break;    case DailyRollingFileAppender.TOP_OF_WEEK:	this.set(Calendar.DAY_OF_WEEK, getFirstDayOfWeek());	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.WEEK_OF_YEAR, 1);	break;    case DailyRollingFileAppender.TOP_OF_MONTH:	this.set(Calendar.DATE, 1);	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.MONTH, 1);	break;    default:	throw new IllegalStateException("Unknown periodicity type.");    }    return getTime();  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人在线一区二区三区| 91精品福利视频| 国产成人av一区二区| 91毛片在线观看| 日韩一区二区三区精品视频 | 成人免费毛片app| 欧美男同性恋视频网站| 国产午夜精品一区二区| 亚洲国产精品天堂| av网站一区二区三区| 日韩精品一区二| 亚洲人成精品久久久久久| 精品一区二区三区蜜桃| 91老师国产黑色丝袜在线| 日韩欧美在线观看一区二区三区| 亚洲综合偷拍欧美一区色| 国产999精品久久久久久| 欧美一区二区在线播放| 久久久99久久| 国产美女精品在线| 欧美猛男超大videosgay| 中文字幕成人网| 亚洲一区二区三区视频在线播放| 国产成人精品免费| 日韩欧美色综合| 丝袜脚交一区二区| 日本韩国精品在线| 国产精品素人一区二区| 日本成人在线电影网| 91在线云播放| 国产精品美女久久久久久久久久久 | 亚洲男女毛片无遮挡| 国产精品素人一区二区| 国产成人av一区二区三区在线| 欧美一级片在线观看| 国产精品免费视频一区| 成人黄色电影在线| 国产日韩影视精品| 日日摸夜夜添夜夜添精品视频| 色88888久久久久久影院野外| 中文字幕在线不卡视频| 91在线高清观看| 最近日韩中文字幕| 97精品久久久久中文字幕| 亚洲自拍偷拍九九九| 91激情五月电影| 亚洲综合色成人| 9191久久久久久久久久久| 蜜臀av一区二区在线免费观看| 欧美欧美欧美欧美首页| 久久国产精品一区二区| 欧美成人r级一区二区三区| 免费成人av在线| 亚洲国产精品激情在线观看| 成人黄页在线观看| 亚洲美女偷拍久久| 日韩欧美在线综合网| 国产乱子伦一区二区三区国色天香 | 久久精品人人做人人综合| 国内成人免费视频| 亚洲欧洲中文日韩久久av乱码| 日本韩国欧美一区| 日韩不卡手机在线v区| 2023国产精华国产精品| 国产99久久精品| 亚洲综合视频在线| 欧美成人欧美edvon| 成人av网址在线| 一区二区三区在线免费播放| 日韩欧美久久久| 成人高清免费在线播放| 自拍av一区二区三区| 在线不卡的av| 国产成人午夜视频| 国产视频一区二区在线| 欧美猛男超大videosgay| 国精品**一区二区三区在线蜜桃| 久久精品夜夜夜夜久久| 日本精品一区二区三区高清| 人禽交欧美网站| 中文av一区二区| 欧美吞精做爰啪啪高潮| 精品一区二区三区久久久| 亚洲欧美激情小说另类| 4438成人网| 成人污视频在线观看| 亚洲成a人片综合在线| 精品裸体舞一区二区三区| 91亚洲午夜精品久久久久久| 天天av天天翘天天综合网色鬼国产| 久久久国产精品麻豆| 777久久久精品| 91激情在线视频| 成人a免费在线看| 一区二区欧美视频| 国产欧美一区二区精品婷婷 | 欧美一区二区在线不卡| 成人黄页在线观看| 国产**成人网毛片九色 | 欧美日韩综合色| 成人免费高清在线| 久久国产欧美日韩精品| 视频在线在亚洲| 亚洲国产日韩av| 成人欧美一区二区三区白人| 欧美电影免费提供在线观看| www.66久久| 国产成人自拍网| 国产最新精品免费| 久久精品久久99精品久久| 亚洲高清免费观看| 一区二区三区四区在线免费观看| 中文子幕无线码一区tr| 欧美tickling挠脚心丨vk| 欧美一级视频精品观看| 91麻豆精品国产91久久久| av在线一区二区| 99在线精品视频| 99国产精品视频免费观看| 国产传媒欧美日韩成人| 国产成人精品aa毛片| 国产福利一区二区| 国产一区二区三区免费在线观看| 激情成人综合网| 国产在线播精品第三| 亚洲三级理论片| 亚洲风情在线资源站| 亚洲最大成人综合| 午夜精品123| 人人精品人人爱| 精品制服美女久久| 国产一区视频导航| 国产91精品在线观看| 成人一区二区三区在线观看| 99久久久久久| 在线视频你懂得一区二区三区| 制服丝袜中文字幕一区| 欧美一区二区三区日韩| 欧美一级欧美三级| 日韩一区二区高清| 久久久青草青青国产亚洲免观| 国产欧美久久久精品影院| 国产区在线观看成人精品| 亚洲欧美日韩国产综合在线| 亚洲综合偷拍欧美一区色| 日韩中文字幕亚洲一区二区va在线| 日韩国产精品大片| 国产一区二区在线观看免费| av电影在线观看一区| 欧洲精品视频在线观看| 91精品国产福利在线观看| 欧美专区日韩专区| 欧美美女直播网站| 337p亚洲精品色噜噜狠狠| 国产精品你懂的| 亚洲第一搞黄网站| 国产成人午夜精品影院观看视频| 91免费视频观看| 欧美一区二区在线视频| 国产日韩视频一区二区三区| 香港成人在线视频| www.亚洲色图| 精品成a人在线观看| 一级精品视频在线观看宜春院 | 欧美一区二区三区日韩| 国产精品久久久久影院色老大| 天天免费综合色| 99re视频精品| 久久久久九九视频| 午夜国产精品一区| 91免费观看国产| 国产三级精品在线| 久久精品国产99久久6| 欧美日韩综合在线| 一区二区三区自拍| fc2成人免费人成在线观看播放 | 风间由美一区二区三区在线观看 | 亚洲视频一区二区免费在线观看 | 开心九九激情九九欧美日韩精美视频电影| 91丨porny丨在线| 国产精品污www在线观看| 久久国产人妖系列| 日韩午夜激情电影| 香蕉久久夜色精品国产使用方法| 色网综合在线观看| 中文字幕一区二区三区不卡在线 | 精品国产百合女同互慰| 日韩一区二区三区视频在线 | 成人午夜大片免费观看| 精品国产91洋老外米糕| 欧美a级理论片| 欧美美女激情18p| 亚洲影视资源网| 在线看日韩精品电影| 一区二区三区电影在线播| 97精品国产97久久久久久久久久久久| 欧美激情一区二区三区不卡 | 国产一区二区三区久久久| 日韩视频免费观看高清完整版| 丝袜诱惑亚洲看片 |