Develop
2015.01.02 18:23
[java] netty (비동기 이벤트 방식 네트워크 프레임워크) 사용법 #1 (server)
조회 수 2210 댓글 1
비동기 이벤트 방식으로 (listener 방식 및 nio) 지원 되는 간단한 framework 가 있어서 정리를
해봅니다. 꼭 한번 다뤄 보고 싶었던 녀석이었는데 이번에 다루게 되네요.
전 이걸 push 서버에다 집어 넣을 생각입니다~~ 생각만 해도 즐겁네요.
일단 서버 쪽 소스를 올려 놓고 2차로 클라이언트 소스를 올려 보겠습니다.
이 녀석의 다운로드는 http://netty.io/ 에서 받으시면 됩니다. (이 녀석 참 파란만장 합니다. apache
mina 부터 시작 해서 jboss 로 갔다가 독립한 모양입니다. 더 대단한건 한국 분이 만드셨답니다~)
어쨌든 소스를 보시면 바로 응용해서 무언가를 만드실 수 있을 겁니다.
전 일단 소켓을 이용한 byte 통신에 필요한 거라 아래 정도만 정리 하는데 다른 점이 필요 하신
분들은 위의 다운로드 사이트에 가서 메뉴얼을 읽어 보시는 게 좋겠습니다.
제 소스는 퀵 스타트 정도로만 보시면 괜찮겠네요.
일단 서버쪽에 클래스 2개가 필요한데
첫번째로 이벤트 핸들러 클래스를 정리 해 보면
package netty.test; 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.ChannelHandlerContext; import org.jboss.netty.channel.ExceptionEvent; import org.jboss.netty.channel.MessageEvent; import org.jboss.netty.channel.SimpleChannelHandler; public class SimpleServerHandler extends SimpleChannelHandler { @Override public void messageReceived(ChannelHandlerContext ctx,MessageEvent e) { ChannelBuffer request = (ChannelBuffer)e.getMessage(); byte[] message = request.array(); System.out.println("message:"+new String(message)); //request 메시지 찍어보기 if(new String(message).equals("1234a")) { ChannelBuffer response = ChannelBuffers.dynamicBuffer(); response.writeBytes("server write test".getBytes()); ChannelFuture future = e.getChannel().write(response); } } public void exceptionCaught(ChannelHandlerContext ctx,ExceptionEvent e) { e.getCause().printStackTrace(); Channel ch = e.getChannel(); ch.close(); } }
두 번째로 서버를 실행 시키는 main 클래스 로직을 살펴 보면
package netty.test; import java.net.InetSocketAddress; import java.util.concurrent.Executors; import org.jboss.netty.bootstrap.ServerBootstrap; import org.jboss.netty.channel.ChannelFactory; 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.NioServerSocketChannelFactory; public class SimpleServer { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub ChannelFactory factory = new NioServerSocketChannelFactory( Executors.newCachedThreadPool(), Executors.newCachedThreadPool() ); //socket 을 nio 를 이용한 channel pool 로 관리 한다. ServerBootstrap bootstrap = new ServerBootstrap(factory); bootstrap.setPipelineFactory(new ChannelPipelineFactory() { @Override public ChannelPipeline getPipeline() throws Exception { // TODO Auto-generated method stub return Channels.pipeline(new SimpleServerHandler()); } }); bootstrap.setOption("child.tcpNoDelay", true); bootstrap.setOption("child.keepAlive", true); bootstrap.bind(new InetSocketAddress(8000)); //열릴 port 가 8000 이라는 뜻입니다. //서버일 경우 bind 를 쓰고 클라이언트일 경우 connect 로 메소드를 쓴다. } }
[출처] http://shonm.tistory.com/397
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
745 | Develop | [php] 몽이가 준 ajax 채팅 소스 ㅋㅋ | hooni | 2013.04.23 | 36174 |
744 | Develop | [php] 메모장 - 웅지학원 ([c] mysql 백업프로그램 포함) | hooni | 2003.04.23 | 6993 |
743 | Develop | [php] 마시마로 캐릭터 방명록 | hooni | 2003.04.23 | 8239 |
742 | Develop | [php] 데이터를 엑셀,워드 형태로 변환할 때 헤더(ms-office) | hooni | 2013.04.23 | 7486 |
741 | Develop | [php] 니우쪽지다.. 받아라~ ^^ | hooni | 2003.04.23 | 9834 |
740 | Develop | [php] 논문 관리 프로그램.. ㅋㅋ | hooni | 2013.04.23 | 7249 |
739 | Develop | [php] 날짜 정보 출력 (년,월,일,시,분,초) | hooni | 2013.04.23 | 10073 |
738 | Develop | [php] 그래프 그리는 프로그램.. | hooni | 2013.04.23 | 8456 |
737 | Develop | [php] XE에서 도메인 별로 광고 다르게 적용하기 | hooni | 2015.01.28 | 608 |
736 | Develop | [php] XE 에서 php 구문 사용하기 (XE 템플릿에서) | hooni | 2013.10.31 | 19433 |
735 | Develop | [php] XE 스킨에서 특정 도메인 리다이렉션 | hooni | 2015.01.28 | 569 |
734 | Develop | [php] XE 관리자 IP대역 설정 오류 해결법 | hooni | 2014.02.10 | 10771 |
전 io. netty밖에 안생겨서 SimpleChannelHandler이랑 @ChannelPipelineCoverage("all"), MessageEvent가 에러가 납니다 ㅜㅜ
그리고, messageReceived랑 channelRead랑 다른점이 뭔가요?