亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Mina、Netty、Twisted一起學(一):實現簡單的TCP服務器

2019-11-14 20:59:33
字體:
來源:轉載
供稿:網友
Mina、Netty、Twisted一起學(一):實現簡單的TCP服務器

MINA、Netty、Twisted為什么放在一起學習?首先,不妨先分別看一下它們官方網站對其的介紹:

MINA:

Apache MINA is a network application framework which helps users develop high performance and high scalability network applications easily. It PRovides an abstract event-driven asynchronous API over various transports such as TCP/ip and UDP/IP via java NIO.

Netty:

Netty is anasynchronous event-drivennetwork application frameworkfor rapid development of maintainable high performance protocol servers & clients.

Twisted:

Twisted is anevent-drivennetworking enginewritten in Python and licensed under the open source MIT license.

(Twisted官網的文案不專業啊,居然不寫asynchronous)

從上面簡短的介紹中,就可以發現它們的共同特點:event-driven以及asynchronous。它們都是事件驅動、異步的網絡編程框架。由此可見,它們之間的共同點還是很明顯的。所以我這里將這三個框架放在一起,實現相同的功能,不但可以用少量的精力學三樣東西,而且還可以對它們之間進行各方面的對比。

其中MINA和Netty是基于Java語言的,而Twisted是Python語言的。不過語言不是重點,重點的是理念。

使用傳統的BIO(Blocking IO/阻塞IO)進行網絡編程時,進行網絡IO讀寫時都會阻塞當前線程,如果實現一個TCP服務器,都需要對每個客戶端連接開啟一個線程,而很多線程可能都在傻傻的阻塞住等待讀寫數據,系統資源消耗大。

而NIO(Non-Blocking IO/非阻塞IO)或AIO(Asynchronous IO/異步IO)則是通過IO多路復用技術實現,不需要為每個連接創建一個線程,其底層實現是通過操作系統的一些特性如select、poll、epoll、iocp等。這三個網絡框架都是基于此實現。

下面分別用這三個框架實現一個最簡單的TCP服務器。當接收到客戶端發過來的字符串后,向客戶端回寫一個字符串作為響應。

Mina:

public class TcpServer {        public static void main(String[] args) throws IOException {          IoAcceptor acceptor = new NioSocketAcceptor();          acceptor.setHandler(new TcpServerHandle());          acceptor.bind(new InetSocketAddress(8080));      }    }    class TcpServerHandle extends IoHandlerAdapter {            @Override      public void exceptionCaught(Iosession session, Throwable cause) throws Exception {          cause.printStackTrace();      }        // 接收到新的數據      @Override      public void messageReceived(IoSession session, Object message) throws Exception {                    // 接收客戶端的數據          IoBuffer ioBuffer = (IoBuffer) message;          byte[] byteArray = new byte[ioBuffer.limit()];          ioBuffer.get(byteArray, 0, ioBuffer.limit());          System.out.println("messageReceived:" + new String(byteArray, "UTF-8"));                    // 發送到客戶端          byte[] responseByteArray = "你好".getBytes("UTF-8");          IoBuffer responseIoBuffer = IoBuffer.allocate(responseByteArray.length);          responseIoBuffer.put(responseByteArray);          responseIoBuffer.flip();          session.write(responseIoBuffer);      }        @Override      public void sessionCreated(IoSession session) throws Exception {          System.out.println("sessionCreated");      }            @Override      public void sessionClosed(IoSession session) throws Exception {          System.out.println("sessionClosed");      }  }  

Netty:

public class TcpServer {        public static void main(String[] args) throws InterruptedException {          EventLoopGroup bossGroup = new NioEventLoopGroup();          EventLoopGroup workerGroup = new NioEventLoopGroup();          try {              ServerBootstrap b = new ServerBootstrap();              b.group(bossGroup, workerGroup)                      .channel(NioServerSocketChannel.class)                      .childHandler(new ChannelInitializer<SocketChannel>() {                          @Override                          public void initChannel(SocketChannel ch)                                  throws Exception {                              ch.pipeline().addLast(new TcpServerHandler());                          }                      });              ChannelFuture f = b.bind(8080).sync();              f.channel().closeFuture().sync();          } finally {              workerGroup.shutdownGracefully();              bossGroup.shutdownGracefully();          }      }    }    class TcpServerHandler extends ChannelInboundHandlerAdapter {        // 接收到新的數據      @Override      public void channelRead(ChannelHandlerContext ctx, Object msg) throws UnsupportedEncodingException {          try {              // 接收客戶端的數據              ByteBuf in = (ByteBuf) msg;              System.out.println("channelRead:" + in.toString(CharsetUtil.UTF_8));                            // 發送到客戶端              byte[] responseByteArray = "你好".getBytes("UTF-8");              ByteBuf out = ctx.alloc().buffer(responseByteArray.length);              out.writeBytes(responseByteArray);              ctx.writeAndFlush(out);                        } finally {              ReferenceCountUtil.release(msg);          }      }            @Override      public void channelActive(ChannelHandlerContext ctx) {          System.out.println("channelActive");      }            @Override      public void channelInactive(ChannelHandlerContext ctx){          System.out.println("channelInactive");      }        @Override      public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {          cause.printStackTrace();          ctx.close();      }  }  

Twisted:

# -*- coding:utf-8 –*-    from twisted.internet.protocol import Protocol  from twisted.internet.protocol import Factory  from twisted.internet import reactor    class TcpServerHandle(Protocol):            # 新的連接建立      def connectionMade(self):          print 'connectionMade'                # 連接斷開      def connectionLost(self, reason):          print 'connectionLost'            # 接收到新數據      def dataReceived(self, data):          print 'dataReceived', data          self.transport.write('你好')    factory = Factory()  factory.protocol = TcpServerHandle  reactor.listenTCP(8080, factory)  reactor.run() 

上面的代碼可以看出,這三個框架實現的TCP服務器,在連接建立、接收到客戶端傳來的數據、連接關閉時,都會觸發某個事件。例如接收到客戶端傳來的數據時,MINA會觸發事件調用messageReceived,Netty會調用channelRead,Twisted會調用dataReceived。編寫代碼時,只需要繼承一個類并重寫響應的方法即可。這就是event-driven事件驅動。

下面是Java寫的一個TCP客戶端用作測試,客戶端沒有使用這三個框架,也沒有使用NIO,只是一個普通的BIO的TCP客戶端。

TCP在建立連接到關閉連接的過程中,可以多次進行發送和接收數據。下面的客戶端發送了兩個字符串到服務器并兩次獲取服務器回應的數據,之間通過Thread.sleep(5000)間隔5秒。

public class TcpClient {            public static void main(String[] args) throws IOException, InterruptedException {                              Socket socket = null;          OutputStream out = null;          InputStream in = null;                    try{                            socket = new Socket("localhost", 8080);                    out = socket.getOutputStream();              in = socket.getInputStream();                            // 請求服務器              out.write("第一次請求".getBytes("UTF-8"));              out.flush();                                    // 獲取服務器響應,輸出              byte[] byteArray = new byte[1024];              int length = in.read(byteArray);              System.out.println(new String(byteArray, 0, length, "UTF-8"));                            Thread.sleep(5000);                            // 再次請求服務器              out.write("第二次請求".getBytes("UTF-8"));              out.flush();                            // 再次獲取服務器響應,輸出              byteArray = new byte[1024];              length = in.read(byteArray);              System.out.println(new String(byteArray, 0, length, "UTF-8"));                                      } finally {              // 關閉連接              in.close();              out.close();              socket.close();          }      }  }  

用客戶端分別測試上面三個TCP服務器:

MINA服務器輸出結果:

sessionCreatedmessageReceived:第一次請求messageReceived:第二次請求sessionClosed

Netty服務器輸出結果:

channelActivechannelRead:第一次請求channelRead:第二次請求channelInactive

Twisted服務器輸出結果:

connectionMadedataReceived: 第一次請求dataReceived: 第二次請求connectionLost


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区三区在线免费观看| 狠狠躁夜夜躁久久躁别揉| 欧美极品在线播放| 亚洲色图15p| 九九热精品视频在线播放| 日韩高清电影免费观看完整| 久久久久久久久久久亚洲| 国产综合久久久久| 国产精品福利无圣光在线一区| 91久久精品久久国产性色也91| 97香蕉超级碰碰久久免费的优势| 国产精品偷伦免费视频观看的| 最新国产精品拍自在线播放| 日本精品性网站在线观看| 欧美中文在线字幕| 久久成人精品视频| 国产精品成人v| 精品亚洲一区二区三区| 一区二区欧美激情| 成人在线精品视频| 日韩电影免费在线观看中文字幕| 国产精品久久久久久久久免费| 久久这里只有精品视频首页| 亚洲高清免费观看高清完整版| 色婷婷亚洲mv天堂mv在影片| 2018日韩中文字幕| 欧美日韩午夜剧场| 精品久久久999| 国产亚洲成av人片在线观看桃| 亚洲自拍高清视频网站| 91成品人片a无限观看| 欧美日韩国产二区| 日韩欧美中文免费| 欧美黑人性视频| 欧美亚洲伦理www| 国产成人综合精品在线| 久久中文字幕一区| 精品国产乱码久久久久久婷婷| 日韩在线观看免费网站| 久久精品国产久精国产思思| 亚洲电影免费观看高清完整版| 伊人久久久久久久久久| 黄网站色欧美视频| 亚洲a区在线视频| 国产成人极品视频| 国产一区二区在线免费视频| 精品国产欧美一区二区三区成人| 精品国产一区av| 国产精品白丝av嫩草影院| 国产精品久久久av久久久| 尤物精品国产第一福利三区| 欧美亚洲午夜视频在线观看| 国产精品都在这里| 亚洲国产精品福利| 欧美诱惑福利视频| 日韩亚洲欧美中文高清在线| 成人精品一区二区三区电影免费| 亚洲第一网站男人都懂| 日韩精品免费看| 成人做爰www免费看视频网站| 欧美性理论片在线观看片免费| 久久久91精品国产| 亚洲第一网站男人都懂| 精品欧美一区二区三区| 456亚洲影院| 精品视频偷偷看在线观看| 亚洲第一网站免费视频| 一区二区三区动漫| 隔壁老王国产在线精品| 欧美视频中文在线看| 中文字幕日韩专区| 欧美成人亚洲成人| 亚洲二区在线播放视频| 欧美日韩亚洲激情| 大荫蒂欧美视频另类xxxx| 日韩欧美一区二区在线| 97香蕉久久夜色精品国产| 日韩免费中文字幕| 91久久精品久久国产性色也91| 久久精品99国产精品酒店日本| 91视频国产一区| 免费97视频在线精品国自产拍| 国产亚洲精品日韩| 91精品中文在线| 色综合伊人色综合网| 国产精品男女猛烈高潮激情| 亚洲国产日韩欧美在线图片| 亚洲自拍小视频免费观看| 久久久久久久久国产| 91精品国产沙发| 中文字幕亚洲综合久久| 亚洲欧美精品中文字幕在线| 久久人体大胆视频| 亚洲精品免费一区二区三区| 日韩精品中文字幕在线播放| 正在播放欧美一区| 国产精品入口福利| 欧美成人激情视频免费观看| 精品视频在线观看日韩| 欧美精品情趣视频| 久久精品国产电影| 亚洲欧洲在线免费| 久久成人精品视频| 国产一区二区欧美日韩| 国产日韩欧美视频在线| 国产精品爽黄69| 久久久久久中文| 九九热99久久久国产盗摄| 亚洲国产日韩一区| 日韩免费av片在线观看| 最新的欧美黄色| 欧美成人午夜影院| 国产成人av网址| 久久夜精品va视频免费观看| 国产视频久久久久久久| 成人观看高清在线观看免费| 97久久精品国产| 欧美最猛性xxxx| 亚洲小视频在线观看| 国色天香2019中文字幕在线观看| 亚洲成色777777女色窝| 日韩视频在线免费观看| 日韩国产高清污视频在线观看| 91成人性视频| 精品动漫一区二区| 国产成人综合一区二区三区| 中文字幕亚洲一区| 日本一区二区不卡| 91久久综合亚洲鲁鲁五月天| 日本一区二区三区在线播放| 欧美性猛交xxxx乱大交蜜桃| 亚洲综合av影视| 日韩成人中文字幕| 国产欧美婷婷中文| 亚洲色图25p| 久久久成人av| 亚洲美女av在线| 91久久精品国产91性色| 国产精品久久久久久久久久久久久| 成人激情视频在线播放| 久久久噜噜噜久噜久久| 欧美成人免费在线视频| 草民午夜欧美限制a级福利片| 欧美精品电影免费在线观看| 国产aⅴ夜夜欢一区二区三区| 91夜夜未满十八勿入爽爽影院| 久久成人精品一区二区三区| 欧美在线激情视频| 欧美一区二区三区免费观看| 亚洲欧美成人一区二区在线电影| 91久久精品视频| 欧美午夜精品久久久久久人妖| 日韩欧美精品中文字幕| 久久久久久久成人| 精品国产福利视频| 国产精品久久久| 91亚洲国产成人精品性色| 欧美日韩成人精品| 日本sm极度另类视频| 欧美大胆在线视频| 国产suv精品一区二区| 欧美国产日韩精品| 欧美成年人网站| 亚洲欧美一区二区三区四区|