<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Jhonney的專欄

       ----人見人愛
    隨筆 - 49, 文章 - 1, 評論 - 23, 引用 - 0
    數據加載中……

    關于log4j重復輸出的問題

    ???今天接著昨天的工作干,把自己寫的框架和程序結合,具體測試一下框架。代碼全部跑通后,一個師妹問了一個關于JDBC的問題,由于以前開發多數底層要么用的工具,要么別人已經封裝好了,所以對這個問題弄了半天,關于ResultSet中sql用select a.*,b* from..的問題,問題是程序老是報超出邊界的錯誤,結論是像前面的sql語句java只認為只有2列,解決辦法需要寫清各個列。
    ???由于這件事的問題,我感到項目中他們數據庫底層沒有統一,且沒有調試工具,我寫的框架其實很早就寫好了,但一直沒有給他們講,所以今天想寫個關于框架使用的ppt,
    ?? 這時就碰到了Log4j重復輸出的問題,摸索一會兒,感覺應該出在log4j的logger繼承上,但一直找不到原因,后來偶爾翻到刑紅瑞的blog,才知道錯誤,錯誤解決辦法:
    【quto to 賈斯汀的網志
    log4j重復輸出log信息原因和解決辦法
    ???????????????????????????????????????
    log4j的logger(舊版本稱logger)是層次結構的,子logger會繼承父logger的屬性,appender也是可繼承的屬性,這常常容易導致配置錯誤而引起的log4j輸出重復的log信息
    log4j的logger(舊版本稱logger)是層次結構的,子logger會繼承父logger的屬性,appender也是可繼承的屬性,這常常容易導致配置錯誤而引起的log4j輸出重復的log信息。如果在在父子logger中引用了相同的appender時,例子:
    ????
    <logger?name="com.erry.model">
    ????????
    <level?value="DEBUG"/>
    ????????
    <appender-ref?ref="CONSOLE"/>
    ????
    </logger>
    ????
    <logger?name="com.erry.service">
    ????????
    <level?value="DEBUG"/>
    ????????
    <appender-ref?ref="CONSOLE"/>
    ????
    </logger>
    ????
    <root>
    ????????
    <level?value="WARN"/>
    ????????
    <appender-ref?ref="CONSOLE"/>
    ????
    </root>

    由于子logger(com.erry.model和com.erry.service)繼承了父logger(ROOT)的appender,加上其本身引用的appender總共會在2個appender上輸出消息,由于這兩個appender實際上是同一個appender,所以結果會是相同的消息被重復輸出。解決這個問題很簡單,只要注意不要重復引用父logger已經引用的appender即可。上述例子的正確配置如下:
    ????
    <logger?name="com.erry.model">
    ????????
    <level?value="DEBUG"/>
    ????
    </logger>
    ????
    <logger?name="com.erry.service">
    ????????
    <level?value="DEBUG"/>
    ????
    </logger>
    ????
    <root>
    ????????
    <level?value="WARN"/>
    ????????
    <appender-ref?ref="CONSOLE"/>
    ????
    </root>



    posted on 2007-03-23 18:14 Jhonney 閱讀(2279) 評論(1)  編輯  收藏

    評論

    # re: 關于log4j重復輸出的問題  回復  更多評論   

    感謝分享~~
    2011-07-27 16:53 | herry

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲6080yy久久无码产自国产 | 99在线观看视频免费| 一级毛片免费毛片一级毛片免费| jjizz全部免费看片| 四虎成人免费大片在线| 亚洲成人一区二区| 久久精品国产亚洲av水果派| 亚洲乱码无人区卡1卡2卡3| 亚洲一级片免费看| 美女内射毛片在线看免费人动物| 日本19禁啪啪无遮挡免费动图| 亚洲小说区图片区另类春色| 亚洲一区在线免费观看| 中文字幕亚洲码在线| 黄床大片免费30分钟国产精品| 久久久久av无码免费网| 亚洲成AV人片在线观看| 日本亚洲精品色婷婷在线影院| gogo免费在线观看| 免费人成网站在线播放| 久久久久亚洲AV无码专区首JN| 国产综合激情在线亚洲第一页| 精品无码人妻一区二区免费蜜桃| 免费人成网站在线高清| 久久综合亚洲色hezyo| 日本牲交大片免费观看| 免费国产va视频永久在线观看| 毛片免费视频在线观看| 日韩在线视频免费看| 亚洲GV天堂GV无码男同| 四虎在线成人免费网站| 亚洲av无码片区一区二区三区| 成年人性生活免费视频| 久久无码av亚洲精品色午夜| 亚洲午夜福利精品久久| 亚洲爆乳无码专区www| 亚洲国产精品成人久久蜜臀 | 三级片免费观看久久| 黄网址在线永久免费观看| 少妇中文字幕乱码亚洲影视| A在线观看免费网站大全|