1. import java.io.IOException;
    2. import java.util.concurrent.TimeUnit;
    3. import javax.servlet.ServletException;
    4. import javax.servlet.annotation.WebServlet;
    5. import javax.servlet.http.HttpServlet;
    6. import javax.servlet.http.HttpServletRequest;
    7. import javax.servlet.http.HttpServletResponse;
    8. /**
    9. * Servlet implementation class SyncServlet
    10. */
    11. @WebServlet("/SyncServlet")
    12. public class SyncServlet extends HttpServlet {
    13. private static final long serialVersionUID = 1L;
    14. /**
    15. * @see HttpServlet#HttpServlet()
    16. */
    17. public SyncServlet() {
    18. super();
    19. // TODO Auto-generated constructor stub
    20. }
    21. /**
    22. * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
    23. * response)
    24. */
    25. protected void doGet(HttpServletRequest request,
    26. HttpServletResponse response) throws ServletException, IOException {
    27. long t1 = System.currentTimeMillis();
    28. // 执行业务代码
    29. doSomeThing(request, response);
    30. System.out.println("sync use:" + (System.currentTimeMillis() - t1));
    31. }
    32. private void doSomeThing(HttpServletRequest request,
    33. HttpServletResponse response) throws IOException {
    34. // 模拟耗时操作
    35. try {
    36. TimeUnit.SECONDS.sleep(5);
    37. } catch (InterruptedException e) {
    38. }
    39. //
    40. response.getWriter().append("done");
    41. }
    42. /**
    43. * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
    44. * response)
    45. */
    46. protected void doPost(HttpServletRequest request,
    47. HttpServletResponse response) throws ServletException, IOException {
    48. // TODO Auto-generated method stub
    49. doGet(request, response);
    50. }
    51. }