Сервлет, кажется, обрабатывает несколько одновременных запросов браузера синхронно

Насколько я знаю, сервлеты Java обрабатывают несколько запросов одновременно, и я поискал через StackOverflow, а также через Google, и подтвердил то, что думал. Однако сейчас я очень запутался, я написал простые сервлеты, которые, кажется, показывают блокирующее поведение.

Итак, у меня есть простой сервлет:

public class MyServlet extends HttpServlet 
{
    private static final long serialVersionUID = 2628320200587071622L;

    private static final Logger logger = Logger.getLogger(MyServlet.class);

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException 
    {
        logger.info("[doGet] Test before");

        try {
            Thread.sleep(60000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        logger.info("[doGet] Test after");

        resp.setContentType("text/plain");
        resp.getWriter().write("OK");

    }
}

Затем у меня есть 2 окна браузера, которые я открыл одновременно, которые попали в мой сервлет. И в результате первый запрос блокирует второе. Журнал также показывает:

10:49:05,088 [http-8383-Processor14]  INFO MyServlet - [doGet] Test before
10:50:05,096 [http-8383-Processor14]  INFO MyServlet - [doGet] Test after
10:50:05,106 [http-8383-Processor22]  INFO MyServlet - [doGet] Test before
10:51:05,112 [http-8383-Processor22]  INFO MyServlet - [doGet] Test after

Мне кажется, что я чего-то упускаю ... Предполагается, что сервлеты могут обрабатывать параллельные запросы, но похоже, что они этого не делают. Я также сделал то же самое для метода службы вместо doGet, и он делает то же самое.

Есть указатели?

Спасибо

24
задан Peter Hall 4 September 2018 в 07:32
поделиться