Develop
2015.01.02 18:32
[java] netty (비동기 이벤트 방식 네트워크 프레임워크) 사용법 #2 (client)
조회 수 2135 댓글 0
바로 이어서 client 로직을 올려 봅니다.
여기도 2개의 클래스 입니다.
첫 번째로 이벤트 핸들러 클래스 입니다.
package com.incross.netty; import org.jboss.netty.buffer.ChannelBuffer; import org.jboss.netty.buffer.ChannelBuffers; import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.ChannelFuture; import org.jboss.netty.channel.ChannelFutureListener; import org.jboss.netty.channel.ChannelHandlerContext; import org.jboss.netty.channel.ChannelStateEvent; import org.jboss.netty.channel.ExceptionEvent; import org.jboss.netty.channel.MessageEvent; import org.jboss.netty.channel.SimpleChannelHandler; public class SimpleClientHandler extends SimpleChannelHandler { @Override public void messageReceived(ChannelHandlerContext ctx,MessageEvent e) { ChannelBuffer response = (ChannelBuffer)e.getMessage(); byte[] message = response.array(); System.out.println("message:"+new String(message)); //response 메시지 찍어보기 if(new String(message).equals("server write test")) { //어떤 조건이 들어왔을 때 종료 되는 로직 Channel ch = e.getChannel(); ch.close(); System.out.println("closed"); } } //connection 연결 하면 바로 데이터 전송 하도록 하는 메소드 @Override public void channelConnected(ChannelHandlerContext ctx,ChannelStateEvent e) { Channel ch = e.getChannel(); ChannelBuffer buf = ChannelBuffers.dynamicBuffer(); buf.writeBytes("1234a".getBytes()); ChannelFuture future = ch.write(buf); future.addListener(new ChannelFutureListener() { public void operationComplete(ChannelFuture future) { Channel ch = future.getChannel(); //ch.close(); //보내고 응답 안받고 끝내려면 close 해주면 됨 } }); } public void exceptionCaught(ChannelHandlerContext ctx,ExceptionEvent e) { e.getCause().printStackTrace(); Channel ch = e.getChannel(); ch.close(); } }
두 번째로 클라이언트 쪽의 main 클래스 입니다.
package com.incross.netty; import java.net.InetSocketAddress; import java.util.concurrent.Executors; import org.jboss.netty.bootstrap.ClientBootstrap; import org.jboss.netty.channel.ChannelFactory; import org.jboss.netty.channel.ChannelFuture; import org.jboss.netty.channel.ChannelPipeline; import org.jboss.netty.channel.ChannelPipelineFactory; import org.jboss.netty.channel.Channels; import org.jboss.netty.channel.socket.nio.NioClientSocketChannelFactory; public class SimpleClient { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub int port = 8000; ChannelFactory factory = new NioClientSocketChannelFactory( Executors.newCachedThreadPool(), Executors.newCachedThreadPool() ); ClientBootstrap bootstrap = new ClientBootstrap(factory); bootstrap.setPipelineFactory(new ChannelPipelineFactory() { @Override public ChannelPipeline getPipeline() throws Exception { // TODO Auto-generated method stub return Channels.pipeline(new SimpleClientHandler()); } }); bootstrap.setOption("tcpNoDelay", true); bootstrap.setOption("keepAlive", true); ChannelFuture future = bootstrap.connect(new InetSocketAddress("localhost",port)); // 아래 부터는 connection 끊어 졌을 때를 위한 처리 future.awaitUninterruptibly(); if(!future.isSuccess()) { future.getCause().printStackTrace(); } future.getChannel().getCloseFuture().awaitUninterruptibly(); factory.releaseExternalResources(); //connection 끊어졌을 때 자원 회수 } }
[출처] http://shonm.tistory.com/398
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
1173 | System/OS | 해커스랩 깨기.. 후후.. ㅋㅋ | hooni | 2013.04.23 | 18530 |
1172 | Etc | 플라스터(Plaster) 수업 내용 | hooni | 2016.05.24 | 0 |
1171 | Develop | 프로그램 문서 관리 (Doxygen) | hooni | 2013.04.23 | 16446 |
1170 | Develop | 프로그래밍에서 foo, bar 함수의 유래 | hooni | 2013.06.25 | 21488 |
1169 | Develop | 프로그래밍 소스 관련 사이트.. | hooni | 2013.04.23 | 16533 |
1168 | Develop | 페이팔에서 돈 찾기 (Paypal withdraw) | hooni | 2014.02.20 | 11487 |
1167 | Etc | 티스토리 테이블 html,css 구문 | hooni | 2013.11.03 | 16065 |
1166 | System/OS | 콘솔에서 패스워드 걸린 zip 압축하는 명령 | hooni | 2018.03.02 | 1145 |
1165 | System/OS | 컴파일러 수업 자료(교재 : 컴파일러 입문) | hooni | 2003.04.23 | 22080 |
1164 | Develop | 캘리포니아 운전면허 족보 | hooni | 2017.06.12 | 899 |
1163 | Etc | 캘리포니아 운전면허 문제 | hooni | 2017.07.22 | 1199 |
1162 | Develop | 최근 논문 자료 (2011/01/03, 만현형한테 보낸거..) | hooni | 2013.04.23 | 10366 |