關于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>


???由于這件事的問題,我感到項目中他們數據庫底層沒有統一,且沒有調試工具,我寫的框架其實很早就寫好了,但一直沒有給他們講,所以今天想寫個關于框架使用的ppt,
?? 這時就碰到了Log4j重復輸出的問題,摸索一會兒,感覺應該出在log4j的logger繼承上,但一直找不到原因,后來偶爾翻到刑紅瑞的blog,才知道錯誤,錯誤解決辦法:
【quto to 賈斯汀的網志】































