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
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
add a comment |
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
add a comment |
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
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
netty
asked Mar 7 at 17:09
user2820352user2820352
111
111
add a comment |
add a comment |
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
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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