Netty是JBOSS針對網絡開發的一套應用框架,它也是在NIO的基礎上發展起來的。netty基於異步的事件驅動,具有高性能、高擴展性等特性,它提供了統一的底層協議接口,使得開發者從底層的網絡協議(比如 TCP/IP、UDP)中解脫出來。就使用來說,開發者只要參考 Netty提供的若干例子和它的指南文檔,就可以放手開發基於Netty的服務端程序了。
Netty 的詳細介紹:請點這裡
Netty 的下載地址:請點這裡
相關閱讀:Netty源碼學習筆記 http://www.linuxidc.com/Linux/2013-09/89778.htm
netty有幾個比較重要的概念,在此,僅做介紹,詳細可以參考netty文檔或源碼。
1). channelBuffer: 是 Netty 的一個基本數據結構,這個數據結構存儲了一個字節序列。 類似於 NIO 的 ByteBuffer,但操作起來比ByteBuffer更為簡單方便。
2). ChannelFactory 是一個創建和管理 Channel 通道及其相關資源的工廠接口,它處理所有的 I/O 請求並產生相應的 I/O ChannelEvent 通道事件。
3).ChannelHandler是所有I/O ChannelEvent事件的響應類,所有消息,包括netty通信異常事件,均在該響應類內處理。
4).*** Bootstrap 是一個設置服務的幫助類。你甚至可以在這個服務中直接設置一個 Channel 通道。
現在以實現一個UDP協議下的服務器應用程序為例,演示netty通過spring注解開發服務器端。(在此以maven工具管理項目開發)
首先,是導入關聯jar的POM文件:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.byd.example</groupId>
<artifactId>nettyTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>nettyTest</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.9</version>
</dependency>
<dependency>
<groupId>org.jboss.netty</groupId>
<artifactId>netty</artifactId>
<version>3.2.0.BETA1</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
</dependencies>
<repositories>
<repository>
<id>repository.jboss.org</id>
<url>http://repository.jboss.org/nexus/content/groups/public/</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<build>
</build>
</project>
更多詳情請繼續閱讀第2頁的內容: http://www.linuxidc.com/Linux/2013-09/89780p2.htm