1
resposta

Tomcat instancia Servlet duas vezes

Ao testar o funcionamento de instanciação do Servlet, utilizando o atributo loadOnStartup , vi que o Tomcat imprimiu a mensagem dentro do construtor do Servlet duas vezes.

Código do Servlet:

package br.com.alura.gerenciador.servlet;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


@SuppressWarnings("serial")
@WebServlet(urlPatterns = {"/oi", "/ola", "/olamundo"}, loadOnStartup = 1)
public class OiMundoServlet extends HttpServlet {

    public OiMundoServlet() {
        System.out.println("Instanciando OiMundoServlet");
    }

    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws IOException {
        System.out.println("Chamando OiMundoServlet.service()");
        resp.setCharacterEncoding("utf-8");

        PrintWriter out = resp.getWriter();

        out.println("<!DOCTYPE html>");
        out.println("<html>");
        out.println("<head>");
        out.println("<meta charset=\"utf-8\">");
        out.println("</head>");
        out.println("<body>");
        out.println("<h1>");
        out.println("Meu Primeiro Servlet ÊÊ");
        out.println("</h1>");
        out.println("</body>");
        out.println("</html>");

        out.close();
    }

}

Parte da mensagem no console:

[...]
INFORMAÇÕES: Starting Servlet engine: [Apache Tomcat/9.0.20]
Instanciando OiMundoServlet // PRIMEIRA INSTANCIAÇÃO
mai 21, 2019 3:20:42 PM org.apache.coyote.AbstractProtocol start
INFORMAÇÕES: Starting ProtocolHandler ["http-nio-8080"]
mai 21, 2019 3:20:42 PM org.apache.coyote.AbstractProtocol start
INFORMAÇÕES: Starting ProtocolHandler ["ajp-nio-8009"]
mai 21, 2019 3:20:42 PM org.apache.catalina.startup.Catalina start
INFORMAÇÕES: Server startup in [745] milliseconds
Instanciando OiMundoServlet // SEGUNDA INSTANCIAÇÃO
Chamando OiMundoServlet.service()
Chamando OiMundoServlet.service()
Chamando OiMundoServlet.service()
Chamando OiMundoServlet.service()
Chamando OiMundoServlet.service()

Isso é normal?

1 resposta

Você deve estar criando duas instâncias, como está seu web.xml?

Uma instância:

 <servlet> 
    <servlet-class>br.com.alura.gerenciador.servlet.OiMundoServlet</servlet-class>
  </servlet>

Duas instâncias: @WebServlet

Se você remover o servlet do web.xml e adicionar ao @WebServlet loadOnStartup=1 deve resolver.