Netty Server not sending all data when channel is closed2019 Community Moderator ElectionNetty not closing channels normalyKeep client from closing connection to a netty server (is there something I need to set)?What's the best way to reconnect after connection closed in NettyUnable to connect to Netty Server twiceNetty close/unbind server channelNetty, Android| IO event polling frequencyClose unused Netty threadsHandle HTTP client exception in nettyCan there be multiple eventloop threads for Netty UDP server?Netty client generates lots of TIME_WAIT socket states

Relation between independence and correlation of uniform random variables

Can a medieval gyroplane be built?

If "dar" means "to give", what does "daros" mean?

Variable completely messes up echoed string

How are passwords stolen from companies if they only store hashes?

Would it be believable to defy demographics in a story?

Calculate the frequency of characters in a string

I got the following comment from a reputed math journal. What does it mean?

두음법칙 - When did North and South diverge in pronunciation of initial ㄹ?

Maths symbols and unicode-math input inside siunitx commands

How does 取材で訪れた integrate into this sentence?

Why didn't Héctor fade away after this character died in the movie Coco?

Writing in a Christian voice

Describing a chess game in a novel

Loading the leaflet Map in Lightning Web Component

How to define limit operations in general topological spaces? Are nets able to do this?

What does "Four-F." mean?

Pronounciation of the combination "st" in spanish accents

Optimising a list searching algorithm

Existence of a celestial body big enough for early civilization to be thought of as a second moon

Have the tides ever turned twice on any open problem?

Print last inputted byte

Bash - pair each line of file

World War I as a war of liberals against authoritarians?



Netty Server not sending all data when channel is closed



2019 Community Moderator ElectionNetty not closing channels normalyKeep client from closing connection to a netty server (is there something I need to set)?What's the best way to reconnect after connection closed in NettyUnable to connect to Netty Server twiceNetty close/unbind server channelNetty, Android| IO event polling frequencyClose unused Netty threadsHandle HTTP client exception in nettyCan there be multiple eventloop threads for Netty UDP server?Netty client generates lots of TIME_WAIT socket states










2















I am new to netty and dont understand why server response is partially lost in my server. I have already read several questions posted, but i cant solve the problem.



I'm using netty 4.0.46 version.
The server must close the connection once it has sent all response data.
I'm using a SimpleChannelInboundHandler, and try to close the channel by using a ChannelFutureListener once the response is been sent.



public class AlbaranXMLServerHandler extends SimpleChannelInboundHandler<String> {
...
@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception
String host = ((InetSocketAddress)ctx.channel().remoteAddress()).getAddress().getHostAddress();
int port = ((InetSocketAddress)ctx.channel().remoteAddress()).getPort();
logger.debug(String.format("Nueva conexión. host:%s port:%d", host, port));


@Override
public void channelRead0(ChannelHandlerContext ctx, String request)
throws Exception

logger.info("Request received: " + request);
.......

logger.debug("XML Response: " + response);

ChannelFuture future = ctx.writeAndFlush(response);
future.addListener(ChannelFutureListener.CLOSE);
.......



When the response data (an XML string) are few, there is no problem, and the cliente receive the complete XML. But when it comes to a large XML file, the transmision gets interrupted, apparently when teh listener closes the channel.



The server log debug shows always the complete XML Ok.



Is there something i am missing about the way netty writes/closes the channel?



ChannelInitializer



public class AlbaranXMLServerInitializer extends ChannelInitializer<SocketChannel> 
......
@Override
public void initChannel(SocketChannel ch) throws Exception
ChannelPipeline pipeline = ch.pipeline();

// Add the text line codec combination first,
pipeline.addLast("framer", new FixedLengthFrameDecoder(AlbaranXMLServerHandler.TRAMA_PETICION_LONGITUD));
// the encoder and decoder are static as these are sharable
pipeline.addLast("decoder", DECODER);
pipeline.addLast("encoder", ENCODER);

// and then business logic.
pipeline.addLast("handler", new AlbaranXMLServerHandler(rutaAlbaranes, autenticacionRFCService, albaranXMLRFCService, grupoSociedadesRFCService));




Server



 @Service 
public class AlbaranXMLServer extends SocketServerBase {
logger.info("Inicializando el servicio " + this.getClass().getSimpleName() + " ...");

bossGroup = new NioEventLoopGroup();
workerGroup = new NioEventLoopGroup();

try
ServerBootstrap b = new ServerBootstrap();
b.group(bossGroup, workerGroup)
.channel(NioServerSocketChannel.class)
.childHandler(this.getChannelInitializer());

Channel channel = b.bind(port).sync().channel();
logger.info("Finalizada la inicialización del servicio " + this.getClass().getSimpleName());

catch (Exception e)
logger.warn("Error al inicializar el servicio " + this.getClass().getSimpleName(), e);
bossGroup.shutdownGracefully();
workerGroup.shutdownGracefully();










share|improve this question


























    2















    I am new to netty and dont understand why server response is partially lost in my server. I have already read several questions posted, but i cant solve the problem.



    I'm using netty 4.0.46 version.
    The server must close the connection once it has sent all response data.
    I'm using a SimpleChannelInboundHandler, and try to close the channel by using a ChannelFutureListener once the response is been sent.



    public class AlbaranXMLServerHandler extends SimpleChannelInboundHandler<String> {
    ...
    @Override
    public void channelActive(ChannelHandlerContext ctx) throws Exception
    String host = ((InetSocketAddress)ctx.channel().remoteAddress()).getAddress().getHostAddress();
    int port = ((InetSocketAddress)ctx.channel().remoteAddress()).getPort();
    logger.debug(String.format("Nueva conexión. host:%s port:%d", host, port));


    @Override
    public void channelRead0(ChannelHandlerContext ctx, String request)
    throws Exception

    logger.info("Request received: " + request);
    .......

    logger.debug("XML Response: " + response);

    ChannelFuture future = ctx.writeAndFlush(response);
    future.addListener(ChannelFutureListener.CLOSE);
    .......



    When the response data (an XML string) are few, there is no problem, and the cliente receive the complete XML. But when it comes to a large XML file, the transmision gets interrupted, apparently when teh listener closes the channel.



    The server log debug shows always the complete XML Ok.



    Is there something i am missing about the way netty writes/closes the channel?



    ChannelInitializer



    public class AlbaranXMLServerInitializer extends ChannelInitializer<SocketChannel> 
    ......
    @Override
    public void initChannel(SocketChannel ch) throws Exception
    ChannelPipeline pipeline = ch.pipeline();

    // Add the text line codec combination first,
    pipeline.addLast("framer", new FixedLengthFrameDecoder(AlbaranXMLServerHandler.TRAMA_PETICION_LONGITUD));
    // the encoder and decoder are static as these are sharable
    pipeline.addLast("decoder", DECODER);
    pipeline.addLast("encoder", ENCODER);

    // and then business logic.
    pipeline.addLast("handler", new AlbaranXMLServerHandler(rutaAlbaranes, autenticacionRFCService, albaranXMLRFCService, grupoSociedadesRFCService));




    Server



     @Service 
    public class AlbaranXMLServer extends SocketServerBase {
    logger.info("Inicializando el servicio " + this.getClass().getSimpleName() + " ...");

    bossGroup = new NioEventLoopGroup();
    workerGroup = new NioEventLoopGroup();

    try
    ServerBootstrap b = new ServerBootstrap();
    b.group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(this.getChannelInitializer());

    Channel channel = b.bind(port).sync().channel();
    logger.info("Finalizada la inicialización del servicio " + this.getClass().getSimpleName());

    catch (Exception e)
    logger.warn("Error al inicializar el servicio " + this.getClass().getSimpleName(), e);
    bossGroup.shutdownGracefully();
    workerGroup.shutdownGracefully();










    share|improve this question
























      2












      2








      2








      I am new to netty and dont understand why server response is partially lost in my server. I have already read several questions posted, but i cant solve the problem.



      I'm using netty 4.0.46 version.
      The server must close the connection once it has sent all response data.
      I'm using a SimpleChannelInboundHandler, and try to close the channel by using a ChannelFutureListener once the response is been sent.



      public class AlbaranXMLServerHandler extends SimpleChannelInboundHandler<String> {
      ...
      @Override
      public void channelActive(ChannelHandlerContext ctx) throws Exception
      String host = ((InetSocketAddress)ctx.channel().remoteAddress()).getAddress().getHostAddress();
      int port = ((InetSocketAddress)ctx.channel().remoteAddress()).getPort();
      logger.debug(String.format("Nueva conexión. host:%s port:%d", host, port));


      @Override
      public void channelRead0(ChannelHandlerContext ctx, String request)
      throws Exception

      logger.info("Request received: " + request);
      .......

      logger.debug("XML Response: " + response);

      ChannelFuture future = ctx.writeAndFlush(response);
      future.addListener(ChannelFutureListener.CLOSE);
      .......



      When the response data (an XML string) are few, there is no problem, and the cliente receive the complete XML. But when it comes to a large XML file, the transmision gets interrupted, apparently when teh listener closes the channel.



      The server log debug shows always the complete XML Ok.



      Is there something i am missing about the way netty writes/closes the channel?



      ChannelInitializer



      public class AlbaranXMLServerInitializer extends ChannelInitializer<SocketChannel> 
      ......
      @Override
      public void initChannel(SocketChannel ch) throws Exception
      ChannelPipeline pipeline = ch.pipeline();

      // Add the text line codec combination first,
      pipeline.addLast("framer", new FixedLengthFrameDecoder(AlbaranXMLServerHandler.TRAMA_PETICION_LONGITUD));
      // the encoder and decoder are static as these are sharable
      pipeline.addLast("decoder", DECODER);
      pipeline.addLast("encoder", ENCODER);

      // and then business logic.
      pipeline.addLast("handler", new AlbaranXMLServerHandler(rutaAlbaranes, autenticacionRFCService, albaranXMLRFCService, grupoSociedadesRFCService));




      Server



       @Service 
      public class AlbaranXMLServer extends SocketServerBase {
      logger.info("Inicializando el servicio " + this.getClass().getSimpleName() + " ...");

      bossGroup = new NioEventLoopGroup();
      workerGroup = new NioEventLoopGroup();

      try
      ServerBootstrap b = new ServerBootstrap();
      b.group(bossGroup, workerGroup)
      .channel(NioServerSocketChannel.class)
      .childHandler(this.getChannelInitializer());

      Channel channel = b.bind(port).sync().channel();
      logger.info("Finalizada la inicialización del servicio " + this.getClass().getSimpleName());

      catch (Exception e)
      logger.warn("Error al inicializar el servicio " + this.getClass().getSimpleName(), e);
      bossGroup.shutdownGracefully();
      workerGroup.shutdownGracefully();










      share|improve this question














      I am new to netty and dont understand why server response is partially lost in my server. I have already read several questions posted, but i cant solve the problem.



      I'm using netty 4.0.46 version.
      The server must close the connection once it has sent all response data.
      I'm using a SimpleChannelInboundHandler, and try to close the channel by using a ChannelFutureListener once the response is been sent.



      public class AlbaranXMLServerHandler extends SimpleChannelInboundHandler<String> {
      ...
      @Override
      public void channelActive(ChannelHandlerContext ctx) throws Exception
      String host = ((InetSocketAddress)ctx.channel().remoteAddress()).getAddress().getHostAddress();
      int port = ((InetSocketAddress)ctx.channel().remoteAddress()).getPort();
      logger.debug(String.format("Nueva conexión. host:%s port:%d", host, port));


      @Override
      public void channelRead0(ChannelHandlerContext ctx, String request)
      throws Exception

      logger.info("Request received: " + request);
      .......

      logger.debug("XML Response: " + response);

      ChannelFuture future = ctx.writeAndFlush(response);
      future.addListener(ChannelFutureListener.CLOSE);
      .......



      When the response data (an XML string) are few, there is no problem, and the cliente receive the complete XML. But when it comes to a large XML file, the transmision gets interrupted, apparently when teh listener closes the channel.



      The server log debug shows always the complete XML Ok.



      Is there something i am missing about the way netty writes/closes the channel?



      ChannelInitializer



      public class AlbaranXMLServerInitializer extends ChannelInitializer<SocketChannel> 
      ......
      @Override
      public void initChannel(SocketChannel ch) throws Exception
      ChannelPipeline pipeline = ch.pipeline();

      // Add the text line codec combination first,
      pipeline.addLast("framer", new FixedLengthFrameDecoder(AlbaranXMLServerHandler.TRAMA_PETICION_LONGITUD));
      // the encoder and decoder are static as these are sharable
      pipeline.addLast("decoder", DECODER);
      pipeline.addLast("encoder", ENCODER);

      // and then business logic.
      pipeline.addLast("handler", new AlbaranXMLServerHandler(rutaAlbaranes, autenticacionRFCService, albaranXMLRFCService, grupoSociedadesRFCService));




      Server



       @Service 
      public class AlbaranXMLServer extends SocketServerBase {
      logger.info("Inicializando el servicio " + this.getClass().getSimpleName() + " ...");

      bossGroup = new NioEventLoopGroup();
      workerGroup = new NioEventLoopGroup();

      try
      ServerBootstrap b = new ServerBootstrap();
      b.group(bossGroup, workerGroup)
      .channel(NioServerSocketChannel.class)
      .childHandler(this.getChannelInitializer());

      Channel channel = b.bind(port).sync().channel();
      logger.info("Finalizada la inicialización del servicio " + this.getClass().getSimpleName());

      catch (Exception e)
      logger.warn("Error al inicializar el servicio " + this.getClass().getSimpleName(), e);
      bossGroup.shutdownGracefully();
      workerGroup.shutdownGracefully();







      netty






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Mar 7 at 17:09









      user2820352user2820352

      111




      111






















          0






          active

          oldest

          votes











          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55049367%2fnetty-server-not-sending-all-data-when-channel-is-closed%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55049367%2fnetty-server-not-sending-all-data-when-channel-is-closed%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Can't initialize raids on a new ASUS Prime B360M-A motherboard2019 Community Moderator ElectionSimilar to RAID config yet more like mirroring solution?Can't get motherboard serial numberWhy does the BIOS entry point start with a WBINVD instruction?UEFI performance Asus Maximus V Extreme

          Identity Server 4 is not redirecting to Angular app after login2019 Community Moderator ElectionIdentity Server 4 and dockerIdentityserver implicit flow unauthorized_clientIdentityServer Hybrid Flow - Access Token is null after user successful loginIdentity Server to MVC client : Page Redirect After loginLogin with Steam OpenId(oidc-client-js)Identity Server 4+.NET Core 2.0 + IdentityIdentityServer4 post-login redirect not working in Edge browserCall to IdentityServer4 generates System.NullReferenceException: Object reference not set to an instance of an objectIdentityServer4 without HTTPS not workingHow to get Authorization code from identity server without login form

          2005 Ahvaz unrest Contents Background Causes Casualties Aftermath See also References Navigation menue"At Least 10 Are Killed by Bombs in Iran""Iran"Archived"Arab-Iranians in Iran to make April 15 'Day of Fury'"State of Mind, State of Order: Reactions to Ethnic Unrest in the Islamic Republic of Iran.10.1111/j.1754-9469.2008.00028.x"Iran hangs Arab separatists"Iran Overview from ArchivedConstitution of the Islamic Republic of Iran"Tehran puzzled by forged 'riots' letter""Iran and its minorities: Down in the second class""Iran: Handling Of Ahvaz Unrest Could End With Televised Confessions""Bombings Rock Iran Ahead of Election""Five die in Iran ethnic clashes""Iran: Need for restraint as anniversary of unrest in Khuzestan approaches"Archived"Iranian Sunni protesters killed in clashes with security forces"Archived