Reputation: 334
I'm using Spring + Log4j. I can see my logs in Eclipse console, but Log4j failed to write into target file.
My web.xml:
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
My log4j.properties: the target file is D:/home/site/wwwroot/logs/swinguserver.log
### set log levels ###
log4j.rootLogger = DEBUG, CONSOLE, LOGFILE
### Settings for Console ###
log4j.appender.CONSOLE = org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Threshold = INFO
log4j.appender.CONSOLE.layout = org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
### Settings for File ###
log4j.appender.LOGFILE = org.apache.log4j.DailyRollingFileAppender
log4j.appender.LOGFILE.File = D:\/home\/site\/wwwroot\/logs\/swinguserver.log
log4j.appender.LOGFILE.Append = true
log4j.appender.LOGFILE.Threshold = DEBUG
log4j.appender.LOGFILE.layout = org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
log4j.appender.LOGFILE.DatePattern = '_'yyyyMMdd'.log'
The java code I use to test Spring + Log4j, the log level is INFO and the log content is : JSONController.getShopInJSON(), name = xxxxxx
@Controller
@RequestMapping("/test")
public class JSONController {
private static final Logger logger = Logger
.getLogger(JSONController.class);
@RequestMapping(value="{name}", method = RequestMethod.GET)
public @ResponseBody Shop getShopInJSON(@PathVariable String name) {
logger.info("JSONController.getShopInJSON(), name = " + name);
Shop shop = new Shop();
shop.setName(name);
shop.setStaffName(new String[]{"mkyong1", "mkyong2"});
return shop;
}
}
When I visit the test url in browser, I can see the desired log in Eclipse console:
However, when I check D:/home/site/wwwroot/logs/swinguserver.log, there is nothing about the test log:
Any suggestion? Thank you guys.
Upvotes: 0
Views: 617
Reputation: 334
It turns out I imported the wrong Logger package... Nothing is wrong with the code I posted.
Upvotes: 1
Reputation: 13
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File= D:/home/site/wwwroot/logs/swinguserver.log
Try above two lines insted of below two lines in your program
log4j.appender.LOGFILE = org.apache.log4j.DailyRollingFileAppender log4j.appender.LOGFILE.File = D:/home/site/wwwroot/logs/swinguserver.log
Upvotes: 0