`
danni505
  • 浏览: 11545 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Server Transport model

阅读更多
介绍
Server Transport 即传输层,是建立在通信信道建立成功和传输指令交互成功的基础上的一层用于传送数据的层,类似TCP、UDP,它的主要的作用就是输送我们定义的数据,数据格式的数据结构则可以自己进行约定,如字符流、字节流等,也可以为XML或其他数据结构实现的数据格式。

在Transport建立过程中,Server与Client端需要持有一些数据成员,如对方的信任信息、连接地址等socket参数、操作柄的代理工厂。

这样建立Transport后则可以实现数据传输、指令下达、报告提交等功能。

部分代码
package thread; 

import java.util.concurrent.LinkedBlockingQueue; 
import java.util.concurrent.ThreadPoolExecutor; 
import java.util.concurrent.TimeUnit; 

import org.apache.commons.logging.Log; 
import org.apache.commons.logging.LogFactory; 

/** 
* This ServerTransport is work in multi thread env    
*    
* @author daniel 
* 
*/ 
public class ServerTransport { 
    
  private static final Log _log = LogFactory.getLog(ServerTransport.class); 
    
  private final Object _lock = new Object(); 
    
  private boolean _readyFlag = false; 
         
        private boolean _stopFlag; 
         
        private final AsynchronousCaller _asyncCaller; 

        /** 
         * Initialization AsynchronousCaller 
         * @param asyncThreadPoolSize 
         */ 
  public ServerTransport(int asyncThreadPoolSize) { 
    if(asyncThreadPoolSize<0){ 
      throw new IllegalArgumentException("illegal Server Transport poolSize: "+asyncThreadPoolSize); 
    } 
    _asyncCaller = new AsynchronousCaller(asyncThreadPoolSize); 
     
    //Do some other things about each transport! 
     
  } 

  /* 
    *    Operate Handler 
    */ 
  //check ready 
  public boolean isReady(){ 
    synchronized(_lock){ 
      return _readyFlag; 
    } 
  } 
    
  //start 
        public void start() throws Exception { 
                if (isStopped()) { 
                        return; 
                } 
                 
                _asyncCaller.start(); 
    
                setReady(true); 
        } 
         
        //stop 
        public void stop() { 
          _asyncCaller.stop(); 
            
          setReady(false); 
          setStop(false); 
        } 
         
        //set ready 
  private void setReady(boolean b) { 
    synchronized(_lock){ 
      _readyFlag = b; 
    } 
  } 
    
  //set ready 
  private void setStop(boolean b) { 
    synchronized(_lock){ 
      _stopFlag = b; 
    } 
  } 
    
  //check stop 
  private boolean isStopped() { 
    synchronized(_lock){ 
      return _stopFlag; 
    } 
  } 
} 

/* 
* Construct an Asynchronous Operate way 
*/ 
class AsynchronousCaller { 

        private final ThreadPoolExecutor _executor; 
         
        /* 
         * Generate an Thread pool with some thread factory & thread group    
         */ 
        public AsynchronousCaller(int poolSize) { 
                if (poolSize <= 0) { 
                        throw new IllegalArgumentException("illegal pool size: "+poolSize); 
                } 
                 
                ThreadGroup threadGroup = new ThreadGroup("Async Caller Group"); 
                 
                ThreadGroupFactory tFactory= new ThreadGroupFactory(threadGroup, "AsyncCaller-"); 
                 
                tFactory.createDaemonThreads(true); 
                 
                _executor =    new ThreadPoolExecutor(poolSize,    
                                                                                        poolSize,    
                                                                                        Long.MAX_VALUE,    
                                                                                        TimeUnit.NANOSECONDS,    
                                                                                        new LinkedBlockingQueue(),    
                                                                                        tFactory, 
                                                                                        new ThreadPoolExecutor.AbortPolicy()); 
        } 

        public void start() { 
                _executor.prestartAllCoreThreads(); 
        } 
         
        public void stop() { 
                _executor.shutdown(); 
        }        
}


  • 大小: 1.1 MB
0
0
分享到:
评论

相关推荐

    TransportLayer_TCP_UDP

    The Transport Layer is a critical component in the OSI (Open Systems Interconnection) model, responsible for ensuring reliable data transmission between hosts. It operates independently of lower-level...

    BLE MES官方协议 mesh profile和mesh model

    - **服务器模型(Server Models)**:提供服务,如控制灯泡亮度的照明模型,或者调节温度的环境传感器模型。 - **客户端模型(Client Models)**:发起请求,如调用远程设备的服务器模型功能。 模型之间通过消息进行...

    LayerRates

    G.852.2 (Enterprise Viewpoint Description of Transport Network Resource Model, March 1999) defines corresponding enterprise-wide network resource concepts that are management abstractions of G.805 ...

    Android调用webservice进行实体对象的传递Json

    为了实现这个过程,你需要在Android项目中引入Gson库,并确保你的实体类(如`ImageModel`)在两端都有对应的定义,包括相同的名字和属性。 三、Android与WebService的通信步骤 1. 创建SoapObject,设置方法名和参数...

    exchange 2010 绝对够详细

    接着,为了安装Exchange 2010的不同角色,如Client Access Server (CAS)、Hub Transport Server (HUB)和Mailbox Server (MB),需要开启PowerShell控制台并以管理员身份运行。在PowerShell中,执行`import-module ...

    RTSPxieyi.rar_c RTSP_live555_rtsp_rtsp server_rtsp协议

    RTSP(Real Time Streaming Protocol,实时流传输协议)是一种应用层协议,用于控制...如果你打算进一步研究,还可以探索RTSP的扩展特性,如SSM(Session Subscription Model)和多播支持,以适应更广泛的应用需求。

    Laravel开发-laravel-kendo-server-filters .zip

    在本压缩包“Laravel开发-laravel-kendo-server-filters .zip”中,重点内容是关于使用Laravel框架与Kendo UI的服务器过滤功能。Laravel是一款流行的PHP框架,用于构建优雅、高效的Web应用程序,而Kendo UI则是一个...

    NIST SP800-52.pdf

    Many books such as [Rescorla01], [Comer00], and [Hall00] describe the Internet’s client-server model and communication protocol design principles. None guide Federal users and system administrators ...

    UNIX Network Programming Volume 1, Third Edition (Unix网络编程卷1第3版英文版)

    The Transport Layer: TCP, UDP, and SCTP Section 2.1. Introduction Section 2.2. The Big Picture Section 2.3. User Datagram Protocol (UDP) Section 2.4. Transmission Control Protocol (TCP) ...

    MVC_Project_-_Transport_Company

    项目与本地MS SQL数据库进行交互,这意味着数据存储和检索都依赖于微软的SQL Server数据库管理系统。这种数据库选择提供了可靠的数据存储和高效的查询性能,适合管理大量运输公司相关的数据,如车辆信息、路线、订单...

    Cisco Press:Storage Networking Protocol Fundamentals.chm

    File Server Protocol Review: CIFS, NFS, and DAFS Backup Protocols: NDMP and EXTENDED COPY Optical Technologies: SONET/SDH, DWDM/CWDM, and RPR/802.17 Virtualization Implementations: Host, ...

    httpcore-4.4.9

    HttpCore is a set of low level HTTP transport components that can be used to build custom client and server side ...blocking, event driven I/O model based on Java NIO.

    Transport-company

    12. **软件架构模式**:如MVC(Model-View-Controller)或MVVM(Model-View-ViewModel)可以帮助组织复杂的项目结构,提高代码的可读性和可维护性。 综上所述,"Transport-company"项目可能涵盖了C#语言的许多核心...

    5ROS仿真.pptx

    ROS提供了许多相机相关的包,如`image_transport`和`camera_info_manager`,用于处理相机数据。 7. **Fiducial Detector Model**: Fiducial探测器模型用于识别机器人环境中的标记物,例如AR标签,帮助机器人定位...

    HttpCore HttpCore4

    HttpCore is a set of low level HTTP transport components that can be used to build custom client and server side ...

    Cisco无线AP配置方法

    no aaa new-model ! dot11 ssid cisco authentication open guest-mode ! ! ! bridge irb ! ! interface Dot11Radio0 no ip address no ip route-cache ! ssid XXXX ! short-slot-time speed basic-1.0 basic-2.0 ...

    asp几个常用邮件组件

    AspEmail是由Mercury Mail Transport System提供的一个ASP邮件组件,它允许开发者通过SMTP服务器发送邮件。AspEmail支持HTML格式的邮件,可以设置发件人、收件人、抄送人、密送人等参数,并能添加附件。使用AspEmail...

Global site tag (gtag.js) - Google Analytics