歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

運用Spring注解實現Netty服務器端UDP應用程序

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

Copyright © Linux教程網 All Rights Reserved