首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从storm拓扑主类调用关闭钩子?

如何从storm拓扑主类调用关闭钩子?
EN

Stack Overflow用户
提问于 2015-02-04 20:23:58
回答 3查看 932关注 0票数 0

我有一个storm拓扑类,它启动了一个kafka spout and bolts。这个类是主类。我正在尝试清理退出风暴拓扑,因此我在该拓扑主方法的旁边创建了一个关闭钩子。

代码语言:javascript
复制
//Shutdown hook
    Runtime.getRuntime().addShutdownHook(new Thread() {
        public void run() {
             System.out.println("Inside shutdown hook.");
             Utils.sleep(1000000);
             cluster.killTopology("netra-fault-management");
             cluster.shutdown();
             logger.info("Shutting down Topology.");
        }
    });

这是我的shutdown钩子,它位于tolpology类的main方法中。我从命令提示符运行它,当我执行ctrl+c时,它应该运行这个关闭钩子,但它只是关闭,没有钩子代码被调用。有没有朋友知道如何在ctrl+c上运行它。

EN

回答 3

Stack Overflow用户

发布于 2015-02-04 20:36:21

使用Runtime#addShutdownHook,这是可能的。

问题应该是由Utils.sleep(1000000);引起的。您不应该让关闭的线程“休眠”,因为Java虚拟机(和其他应用程序)不允许这样做。关机钩子被设计成在应用程序即将关闭时调用,以保存重要的东西或卸载资源等。Java虚拟机将在几秒钟后终止,即使线程没有完全执行。

在极少数情况下,虚拟机可能会中止,即在未完全关闭的情况下停止运行。当虚拟机在外部终止时,例如Unix上的SIGKILL信号或Microsoft Windows上的TerminateProcess调用,就会发生这种情况。如果本机方法因例如破坏内部数据结构或试图访问不存在的存储器而出错,则虚拟机也可能中止。如果虚拟机中止,则不能保证是否将运行任何关闭挂钩。

来自运行时类的JavaDoc。有时不会调用关闭钩子。祝好运!

票数 1
EN

Stack Overflow用户

发布于 2015-06-11 07:12:08

几年前,Nathan Marz在评论一个类似的问题时,我假设行为没有改变:

https://groups.google.com/forum/#!topic/storm-user/A4-uFS6px2Y

Storm使用SIGKILL关闭工作进程,JVM在这些情况下不会执行关闭钩子(就像SIGINT一样)。

票数 0
EN

Stack Overflow用户

发布于 2016-01-28 23:51:10

据我从thisthis了解,他们已经实现了一个更改,允许触发关闭钩子,但钩子代码被限制为一秒,所以在某些情况下是可以的。Hovewer,我没有亲自检查,因为它不足以满足我的情况,这是缓冲区上传。但是对于我来说,有一个替代的approach,我将会实现它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28321305

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档