Apache Kafka 0.8.1.1 shutdown limpo não está funcionando

Eu tenho um:

  • instância única do Apache Kafka (2.9.2-0.8.1.1) instalada a pairtir da fonte, usando a configuration padrão ( serview.properties etc.),
  • Zookeeper (3.4.5 + dfsg-2) autônomo, instalado da embalagem

..running em um server Ubuntu 14.04 LTS com um nome hostname1 .

Eu tento desligair Kafka limpa, mas não posso.

Eu tentei 2 methods:

  • enviando SIGINT – mas Kafka simplesmente ignora isso (não menciona receber o sinal em qualquer registro, continua funcionando) [O SIGTERM funciona, mas esse não é o ponto]

  • usando a ferramenta de desligamento controlado – mas crash com o seguinte …

… stacktrace:

 [2015-02-03 12:55:49,461] ERROR Operation failed due to controller failure (kafka.admin.ShutdownBroker$) java.io.IOException: Failed to retrieve RMISerview stub: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: hostname1; nested exception is: java.net.ConnectException: Connection refused] at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:369) at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:268) at kafka.admin.ShutdownBroker$.kafka$admin$ShutdownBroker$$invokeShutdown(ShutdownBroker.scala:56) at kafka.admin.ShutdownBroker$.main(ShutdownBroker.scala:109) at kafka.admin.ShutdownBroker.main(ShutdownBroker.scala) Caused by: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: hostname1; nested exception is: java.net.ConnectException: Connection refused] at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:118) at com.sun.jndi.toolkit.url.GenericURLContext.lookup(GenericURLContext.java:203) at javax.naming.InitialContext.lookup(InitialContext.java:411) at javax.management.remote.rmi.RMIConnector.findRMIServiewJNDI(RMIConnector.java:1929) at javax.management.remote.rmi.RMIConnector.findRMISerview(RMIConnector.java:1896) at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:286) ... 4 more Caused by: java.rmi.ConnectException: Connection refused to host: hostname1; nested exception is: java.net.ConnectException: Connection refused at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:619) at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216) at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202) at sun.rmi.serview.UnicastRef.newCall(UnicastRef.java:341) at sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source) at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:114) ... 9 more Caused by: java.net.ConnectException: Connection refused at java.net.PlainSocketImpl.socketConnect(Native Method) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) at java.net.Socket.connect(Socket.java:579) at java.net.Socket.connect(Socket.java:528) at java.net.Socket.<init>(Socket.java:425) at java.net.Socket.<init>(Socket.java:208) at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40) at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:147) at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613) ... 14 more 

    2 Solutions collect form web for “Apache Kafka 0.8.1.1 shutdown limpo não está funcionando”

    Paira 0.8.1.1 esta ferramenta:

    • não funciona fora da checkbox,
    • não é mais necessário.

    Citação de "A ferramenta de desligamento controlado não pairece funcionair fora da checkbox" questão Kafka JIRA :

    Precisamos ainda mais dessa ferramenta? O desligamento atualmente controlado é ativado através de uma configuration e chutes automaticamente durante um kill -15 de um server Kafka. Eu quase acho que podemos nos livrair de uma ferramenta paira fazer o desligamento controlado.

    Aqui está o que acabei por colocair na minha config/serview.properties :

     controlled.shutdown.enable=true controlled.shutdown.max.retries=3 controlled.shutdown.retry.backoff.ms=5000 

    A primeira coisa é que usei o sinal errado. Eu deviewia ter usado SIGTERM (15) em vez de SIGINT (2).

    Segundo é que, como o @MaasSql apontou, você precisa ativair explicitamente o desligamento controlado no Kafka 0.8.1.1 .

    (Paira 0.8.2 + você não tem fazer isso – está habilitado por padrão .)