25,980
社区成员
发帖
与我相关
我的任务
分享public class ServerDemo {
private static Logger logger = Logger.getLogger("op");
private static int PORT = 3721;
public static void main(String[] args) {
IoAcceptor acceptor = null;
try {
// 创建一个非阻塞的server端的Socket
acceptor = new NioSocketAcceptor();
// 设置过滤器(使用Mina提供的文本换行符编解码器)
acceptor.getFilterChain().addLast(
"codec",
new ProtocolCodecFilter(new TextLineCodecFactory(Charset
.forName("UTF-8"),
LineDelimiter.WINDOWS.getValue(),
LineDelimiter.WINDOWS.getValue())));
// 设置读取数据的缓冲区大小
acceptor.getSessionConfig().setReadBufferSize(2048);
// 读写通道10秒内无操作进入空闲状态
acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 3);
// 绑定逻辑处理器
acceptor.setHandler(new ServerHandlerDemo());
// 绑定端口
acceptor.bind(new InetSocketAddress(PORT));
} catch (Exception e) {
logger.error("服务端启动异常....", e);
e.printStackTrace();
}
}
}
public class ServerHandlerDemo extends IoHandlerAdapter{
private static Logger logger = Logger.getLogger("op");
@Override
public void sessionCreated(IoSession session) throws Exception {
logger.info("服务端与客户端创建连接...");
}
@Override
public void sessionOpened(IoSession session) throws Exception {
logger.info("服务端与客户端连接打开...");
}
@Override
public void messageReceived(IoSession session, Object message)
throws Exception {
String msg = message.toString();
logger.info("接收信息:"+msg);
try {
session.write("返回信息: XXX");
} catch (Exception e) {
logger.error(e.getMessage());
session.write(e.getMessage());
}
}
@Override
public void messageSent(IoSession session, Object message) throws Exception {
//短连接
session.close(true);
}
@Override
public void sessionClosed(IoSession session) throws Exception {
}
@Override
public void sessionIdle(IoSession session, IdleStatus status)
throws Exception {
logger.info("服务端进入空闲状态...");
}
@Override
public void exceptionCaught(IoSession session, Throwable cause)
throws Exception {
logger.error("服务端发送异常...", cause);
}
public class ClientDemo {
private static Logger logger = Logger.getLogger("op");
private static String HOST = "127.0.0.1";
private static int PORT = 3721;
public static void main(String[] args) {
// 创建一个非阻塞的客户端程序
final IoConnector connector = new NioSocketConnector();
// 设置链接超时时间
connector.setConnectTimeoutMillis(3000);
// 添加过滤器
connector.getFilterChain().addLast(
"codec",
new ProtocolCodecFilter(new TextLineCodecFactory(Charset
.forName("UTF-8"), LineDelimiter.WINDOWS.getValue(),
LineDelimiter.WINDOWS.getValue())));
for (int i = 0; i < 10; i++) {
new Thread(new Runnable() {
@Override
public void run() {
new ClientDemo().visitServer(connector);
}
}).start();
}
}
public void visitServer(IoConnector connector) {
// 添加业务逻辑处理器类
connector.setHandler(new ClientHandlerDemo());
IoSession session = null;
try {
ConnectFuture future = connector.connect(new InetSocketAddress(
HOST, PORT));// 创建连接
future.awaitUninterruptibly();// 等待连接创建完成
session = future.getSession();// 获得session
session.write("mina" + Thread.currentThread().getId());// 发送消息
} catch (Exception e) {
logger.error("客户端链接异常...", e);
}
if (session != null) {
session.getCloseFuture().awaitUninterruptibly();// 等待连接断开
connector.dispose();
} else {
connector.dispose();
}
}
}
public class ClientHandlerDemo extends IoHandlerAdapter{
private static Logger logger = Logger.getLogger("op");
@Override
/**
* 客户端从服务端接受到的信息
*/
public void messageReceived(IoSession session, Object message)
throws Exception {
String msg = message.toString();
logger.info(msg);
}
@Override
public void exceptionCaught(IoSession session, Throwable cause)
throws Exception {
logger.error("客户端发生异常...", cause);
}
}