Java 防波堤:程序性停止导致“;1“无法停止线程”;

Java 防波堤:程序性停止导致“;1“无法停止线程”;,java,jetty,shutdown,Java,Jetty,Shutdown,我有一个嵌入式Jetty 6.1.26实例。 我想通过HTTP将其关闭,并将其发送到/shutdown。 因此,我创建了一个JettyShutdownServlet: @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setStatus(202, "Shutting down."); resp

我有一个嵌入式Jetty 6.1.26实例。 我想通过HTTP将其关闭,并将其发送到
/shutdown
。 因此,我创建了一个
JettyShutdownServlet

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

 resp.setStatus(202, "Shutting down.");
 resp.setContentType("text/plain");
 ServletOutputStream os = resp.getOutputStream();
 os.println("Shutting down.");
 os.close();
 resp.flushBuffer();

 // Stop the server.
 try {
    log.info("Shutting down the server...");
    server.stop();
 } catch (Exception ex) {
    log.error("Error when stopping Jetty server: "+ex.getMessage(), ex);
 }
但是,当我发送请求时,Jetty并没有停止-一个线程一直挂在
org.mortbay.thread.QueuedThreadPool
中,与
this.wait()

它阻塞整整一分钟,然后关闭。 我添加了优雅的关闭,这应该允许我从servlet关闭服务器;但是,它不能像您从日志中看到的那样工作

我是这样解决的:

Server server = new Server( PORT );
server.setGracefulShutdown( 3000 );
server.setStopAtShutdown(true);
...
server.start();

if( server.getThreadPool() instanceof QueuedThreadPool ){
   ((QueuedThreadPool) server.getThreadPool()).setMaxIdleTimeMs( 2000 );
}
setMaxidletimes()
需要在
start()
之后调用,因为线程池是在
start()
中创建的。但是,线程已经创建并正在等待,因此它仅在所有线程至少使用一次后才适用

除了中断所有线程或
System.exit()
,我不知道还能做什么


有什么想法吗?有什么好办法吗?

优雅不会做你认为它会做的事情-它允许服务器优雅地关闭,但不允许你从servlet内部关闭

问题如您链接到的邮件列表帖子中所述-您正在尝试停止服务器,同时仍在处理服务器内部的连接

您应该尝试将servlet的实现更改为:

// Stop the server.
new Thread()
{
   public void run() {
     try {
        log.info("Shutting down the server...");
        server.stop();
        log.info("Server has stopped.");
     } catch (Exception ex) {
        log.error("Error when stopping Jetty server: "+ex.getMessage(), ex);
     }
   }
}.start();

这样,servlet可以在服务器关闭时完成处理,并且不会延迟关闭过程。

我发现了似乎在讨论这个问题的内容——但是,感激的关闭应该能够处理这个问题。这个解决方案是有效的。但是,我不得不添加
Thread.sleep()
,以防止同样的情况发生——线程执行得太快。所以我想知道如何阻止它,直到请求线程结束<代码>联接()由于线程返回到池而不起作用。@ OnDr.i不确定这是否仍然是相关的,但是请考虑一个奇妙的答案,但仍然需要一种处理@ OnDra i i ka的线程(睡眠)的方法。
Server server = new Server( PORT );
server.setGracefulShutdown( 3000 );
server.setStopAtShutdown(true);
...
server.start();

if( server.getThreadPool() instanceof QueuedThreadPool ){
   ((QueuedThreadPool) server.getThreadPool()).setMaxIdleTimeMs( 2000 );
}
// Stop the server.
new Thread()
{
   public void run() {
     try {
        log.info("Shutting down the server...");
        server.stop();
        log.info("Server has stopped.");
     } catch (Exception ex) {
        log.error("Error when stopping Jetty server: "+ex.getMessage(), ex);
     }
   }
}.start();