前提・実現したいこと
現在サーブレットの勉強をしており、以下のJavaコードの疎通を試しています。内容としてはinitメソッドの中でログ(localhost.yyyy-mm-dd.log)を出力し、その中に「"init method is called"」という文言を出力したいです。
発生している問題・エラーメッセージ
現状はログファイル自体が生成されておらず、原因の切り分けも出来ていない状況です。
エラーメッセージなし
該当のソースコード
Java
1package studyservlet; 2 3import java.io.IOException; 4import javax.servlet.ServletConfig; 5import javax.servlet.ServletContext; 6import javax.servlet.ServletException; 7import javax.servlet.annotation.WebServlet; 8import javax.servlet.http.HttpServlet; 9import javax.servlet.http.HttpServletRequest; 10import javax.servlet.http.HttpServletResponse; 11 12/** 13 * Servlet implementation class ServletLifeCycle 14 */ 15@WebServlet("/ServletLifeCycle") 16public class ServletLifeCycle extends HttpServlet { 17 private static final long serialVersionUID = 1L; 18 19 /** 20 * @see HttpServlet#HttpServlet() 21 */ 22 public ServletLifeCycle() { 23 super(); 24 // TODO Auto-generated constructor stub 25 } 26 27 /** 28 * @see Servlet#init(ServletConfig) 29 */ 30 @Override 31 public void init(ServletConfig config) throws ServletException { 32 super.init(config); 33 ServletContext application = this.getServletContext(); 34 application.log("init method is called"); 35 System.out.println("**** Test of Log Generation ****"); 36 } 37 38 /** 39 * @see Servlet#destroy() 40 */ 41 public void destroy() { 42 43 } 44 45 /** 46 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 47 */ 48 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 49 // TODO Auto-generated method stub 50 response.getWriter().append("Served at: ").append(request.getContextPath()); 51 } 52 53 /** 54 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 55 */ 56 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 57 // TODO Auto-generated method stub 58 doGet(request, response); 59 } 60 61} 62
試したこと
まずはservlet.xmlにロガーが登録されているか?をチェックしました。
/usr/local/src/apache-tomcat-8.5.42/conf/servlet.xml
そして登録が無かったため、<Host></Host>内に以下を追加しました。
<Context path="/TestProject" docBase="TestProject" reloadable="true" source="org.eclipse.jst.jee.server:TestProject"/> <Logger className="org.apache.catalina.logger.FileLogger" prefix="HelloLifeCyecle" suffix=".log" timestamp="true" /> </Context>
出力したいログが「localhost_access_log.2019-06-15.txt」ではなく「localhost.yyyy-mm-dd.log」であったため、上記の試した事は間違っていました。代わりに下記を追加で試しました。
「logging.properties」の中身をチェックし、下記の行があることを確認。
1catalina.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
補足情報(FW/ツールのバージョンなど)
OS : CentOS release 6.9 (Final)
Eclipse:Eclipse(OXYGEN)
Tomcat : v8.5
あなたの回答
tips
プレビュー