Я использую Apache Mina 1.1.7 и Java 1.6. Сервер отправляет клиенту последовательность из трех сообщений в цикле. Иногда два набора сообщений перекрываются. Например, я ожидаю:
++ recv: MSGHEAD
++ recv: message body 1
++ recv: .
++ recv: MSGHEAD
++ recv: message body 2
++ recv: .
но вместо этого я получаю это:
++ recv: MSGHEAD
++ recv: MSGHEAD
++ recv: message body 1
++ recv: .
++ recv: message body 2
++ recv: .
Вот моя конфигурация сервера:
SocketAcceptor acceptor = new SocketAcceptor();
SocketAcceptorConfig config = new SocketAcceptorConfig();
config.setThreadModel(ThreadModel.MANUAL);
if (true) {
SSLContextFactory factory = new SSLContextFactory();
config.getFilterChain().addLast("sslFilter", new SSLFilter(factory.getInstance(true)));
}
System.out.println(config.getFilterChain().toString());
config.getFilterChain().addLast("codec", new ProtocolCodecFilter(new TextLineCodecFactory(Charset.forName("UTF-8")) ));
config.getFilterChain().addLast("to-message", new ToMessageIoFilter());
config.getSessionConfig().setReuseAddress( true );
config.getSessionConfig().setTcpNoDelay(true);
acceptor.bind( new InetSocketAddress(PORT), new MinaServerHandler(new MinaConnectionFactory()), config );
}
Вот как я отправляю последовательность сообщений:
public void sendMessage(String msg) throws IOException {
synchronized(session){
writeLine("MSGHEAD");
writeLine(msg);
writeLine(".");
}
}
private void writeLine(String line) {
WriteFuture w=session.write(line);
}
Что я делаю неправильно?