一、Tomcat設置訪問日誌web
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <!-- <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> --> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h,%l,%u,%t,%T,"%r",%s,%b,%{Referer}i,"%{User-Agent}i",%{X-Requested-With}i" fileDateFormat="yyyy-MM-dd.HH" /> </Host>
在pattern中每一個的含義,我參考的是 https://blog.csdn.net/yaerfeng/article/details/40340981spring
二、springboot設置訪問日誌,在配置文件中添加tomcat日誌配置apache
#tomcat訪問日誌
server.tomcat.accesslog.directory=d:/logs
server.tomcat.accesslog.enabled=true
server.tomcat.accesslog.prefix=localhost_access_log.
server.tomcat.accesslog.suffix=.txt
server.tomcat.accesslog.pattern=%h,%l,%u,%t,%T,"%r",%s,%b,%{Referer}i,"%{User-Agent}i",%{X-Requested-With}i,%{passport}c
server.tomcat.accesslog.file-date-format=yyyy-MM-dd
我是添加到application.properties中的tomcat
三、日誌分析,經過正在表達式,將須要分析的信息進行正則捕獲提取,而後根據須要進行相關數據的統計及可視化展現springboot
public static void parse() throws Exception{ String path = "D:/logs/localhost_access_log.2018-09-30.11.txt"; BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(path))); String line = null; String reg = "^(.+?),(.+?),(.+?),(.+?),(.+?),(\\\".+?\\\"),(.+?),(.+?),(.+?),(\\\".+?\\\"),(.+?),(.+?)$"; Pattern pattern = Pattern.compile(reg); while((line=br.readLine())!=null) { System.out.println(line); Matcher matcher = pattern.matcher(line); matcher.matches(); // pattern="%h,%l,%u,%t,%T,"%r",%s,%b,%{Referer}i,"%{User-Agent}i",%{X-Requested-With}i,%{passport}c" System.out.println("ip="+matcher.group(1)); System.out.println("date="+matcher.group(4)); System.out.println("cost="+matcher.group(5)); System.out.println("request="+matcher.group(6)); System.out.println("status="+matcher.group(7)); System.out.println("bytes="+matcher.group(8)); System.out.println("Referer="+matcher.group(9)); System.out.println("User-Agent="+matcher.group(10)); System.out.println("X-Requested-With="+matcher.group(11)); System.out.println("passport="+matcher.group(12)); System.out.println("------------------------------------"); } br.close(); }