SuperSocket基础一

SuperSocket基础(一)——————基本概念



项目中之前一直使用TCP socket服务框架,但是不利于扩展。最近刚接触到开源的superSocket感觉很不错,特记录一下。官方开源地址:http://www.supersocket.net/

基本概念:

SuperSocket:是一个可扩展的Socket开源框架,是一个轻量级、跨平台而且可扩展的.Net/Mono Socket 服务器程序框架。可以轻松的使用SuperSocket开发出一款Socket服务软件。

功能特点:

1、高性能的事件驱动通信。

2、简单易用,创建几个类即可获得一个健壮的Socket服务器。

3、内置的命令协议能够迅速创建一个网络命令行接口服务器。

4、强大的性能的协议解析实现工具简化了网络数据的分析工作。

5、灵活的配置和友好的API。

6、多监听器支持,让一个服务器实例监听多个客户端。

7、多服务器的实例托管的支持复杂的部署需求。

8、应用程序域和进程级别的隔离能够满足大部分的宿主场景。

9、内置的SSL/TLS加密支持。

10、会话级别的发送队列能够通过会话并发送数据,并保持高性能和可控性。

11、SuperSocket的命令处理模式让你的业务逻辑更清晰,更有条例。

12、优良的可扩展 API 支持: Command Filter, Connection Filter, Command Loader;

13、可替换的日志框架能够满足喜欢的日志组件。

14、动态语言的支持,允许Python等脚本语言来实现命令。

15、与Mono/Linux保持二进制级别的兼容。

架构设计示意图:

层次示意图:

层次解析:

SuperSocket 层次

一、设备层:基于flash和SilverLight的策略服务器和基于接收过滤器的协议实施。

二、应用层:可扩展的应用程序服务:包括多种API集成。会话容器和命令框架。

三、套接字层: 通过传输协议TCP和UDP的事件驱动套接字服务。

SuperSocket对象模型示意图

模型解析:

1、应用服务AppServer 包括命令Commands, 会话容器Session contaioner。

2、对象层次:基本配置Config->命令过滤器Command Filters->日志和日志工厂Log/LogFactory->命令装载机CommandLoaders->接收过滤器工厂ReceiveFilterFactory->连接过滤Connection Filters。

3、Socket 服务:多客户端监听,TCP1 、TCP2、。。。。UDP。

SuperSocket 请求处理模型示意图

模型解析:

1、客户端携带数据流与Server端Socket Listener建立连接之后,SuperSocket 服务就将这一个连接视为一个Session会话。表示客户端和服务器端的一个逻辑连接,数据的收发都是在这个Session中进行处理的(此过程中的数据流为二进制数据)。

2、携带数据流的Session通过默认或者自定的接受过滤器将过滤后的数据传递到RequestInfo对象。每一个客户端对象都得实例化一个RequestInfo类,将接收到的二进制流转换成请求的实例。详细的概念将在下文中进行整理总结。

3、根据RequestInfo执行Command命令,一个Command 包含一个Session和RequestInfo,在Command中根据需求解析数据。也可通过Session向客户端发送数据,例如有些DTU或者RTU设备需要发送指令才能返回数据。



通过请求处理模型可以总结基本的开发流程:

1、实例化AppServer对象,时刻监听客户端的会话。

2、定义RequestInfo实体类型,接收和处理二进制字符流。

3、定义数据接收过滤器,ReceiveFilter,接收过滤后的数据,并将数据赋值给RequestInfo实体类型。

4、在appServer的构造函数中继承使用接收过滤工厂RequestFilterFactory,并执行自定的ReceiveFilter和RequestInfo。

5、在1的数据请求委托事件中解析并使用RequestInfo实体中对应的数据。



下一篇以官方实例为例进行总结

时间: 2024-11-08 17:08:55

SuperSocket基础一的相关文章

SuperSocket基础二

SuperSocket基础(二)-----一个完成SocketServer项目 由于时间关系未能及时更新,关于SuperSocket,对于初学者而言,一个SuperSock的Server真的不好写.官方文档写的很清晰,如何接受客户端发来的二进制报文并做响应的解析.下面就从一个完整的项目出发,记录SuperSocket的开发过程. 1.项目场景:现有十多个RTU设备,用来监测自来水管的压力和流量,需要将十多个传感器传来的值接收并做解析来使用.用SuperSocket写一个Socket服务器,实时监

java web 开发三剑客 -------电子书

Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知Internet的目的是让各个net交互.所以,Internet实质上是将世界上各个国家.各个网络运营商的多个网络相互连接构成的一个全球范围内的统一网,使各个网络之间能够相互到达.各个国家和运营商构建网络采用的底层技术和实现可能各不相同,但只要采用统一的上层协议(TCP/IP)就可以通过Internet

SuperSocket 最基础入门(大神忽略)

SuperSocket 是什么? 首先我们明确一下SuperSocket 本质是什么? 网络框架 !  ok , 那么我们直接上上官网,作者已经开源到Github,可以做两件事 : 有没有文档,有的话那么学习起来会方便很多 拿到源码,先让它跑起来    和我一步一个脚印 首先拿到源码,并让Demo跑起来 下载master 分支 然后下载v1.6 版本(具体版本以最新为准) 使用 VS 打开, 下面解释两个分支 master 分支 : SuperSocket 网络框架的源码, v1.6 分支 : 

基于SuperSocket实现的WebSocket(后端)

关于WebSocket其实很早就想发了,奈何之前项目中的WebSocket的后端不是我做的,而我又想前后端都发出来和大家讨论讨论~于是挤出点时间研究了一下WebSocket的后端实现(所以才有了这篇文章). 首先是概念导论,现在大家在百度.谷歌很容易就能搜索到一大堆这样的socket(百度百科).Socket详解(太多了就不一一列举) 看过这些概念导论以后,我们准备先实现WebSocket的服务端(基础概念都没掌握的童鞋们需要补课了). 说到.net的WebSocket实现,就不得不说Super

使用SuperSocket打造逾10万长连接的Socket服务

SuperSocket 是一个轻量级, 跨平台而且可扩展的 .Net/Mono Socket 服务器程序框架.你无须了解如何使用 Socket, 如何维护 Socket 连接和 Socket 如何工作,但是你却可以使用 SuperSocket 很容易的开发出一款 Socket 服务器端软件,例如游戏服务器,GPS 服务器, 工业控制服务和数据采集服务器等等. PS:上面这句话复制官网的,好了,总之告诉大家SuperSocket已经很强大.很稳定.方便. 如果你没有Socket基础,首先要了解协议

Java注解(1)-注解基础

注解(Annotation)是在JAVA5中开始引入的,它为在代码中添加信息提供了一种新的方式.注解在一定程度上把元数据与源代码文件结合在一起,正如许多成熟的框架(Spring)所做的那样.那么,注解到底可以做什么呢? 1.注解的作用. 提供用来完整地描述程序所需要的信息,如编译期校验程序信息. 生成描述符文件,或生成新类的定义. 减轻编写"样板"代码(配置文件)的负担,可以使用注解自动生成. 更加干净易读的代码. 编译期类型检查. 2.Java提供的注解 Java5内置了一些原生的注

MySQL数据库基础知识

day02 MySQL数据库基础知识 一.基础知识概述: 基础决定你这门课程的学习成败!只有学习好这些基础知识以后,你才能真正的运用自如.才能够对数据库有更深入的了解,道路才会越走越远. 二.基础知识: 1.数据库(database):数据库就好比是一个物理的文档柜,一个容器,把我们整理好的数据表等等归纳起来. 创建数据库命令:        create database 数据库名; 2.查看数据库         show databases; 3.打开指定的数据库         use 

【Linux系列】【基础版】第四章 Shell基础之正则表达式

4. Shell基础之正则表达式     4.1 正则就是一串有规律的字符串         4.1 grep              4.1.1 格式: grep [-cinrvABC] 'word' filename             4.1.2 -c //count,表示行数             4.1.3 -i //不区分大小写             4.1.4 -n  //显示行号             4.1.5 -r  //遍历所有子目录             4

NumPy基础:数组和失量计算

NumPy : Numerical Python,是高性能科学计算和数据分析的基础包. 部分功能: ndarray:一个具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组: 用于对整组数据进行快速运算的标准数学函数(无需编写循环): 用于读写磁盘数据的工具以及用于操作内存映射文件的工具: 线性代数.随机数生成以及傅里叶变换功能: 用于集成C.C++.Fortran等语言编写的代码工具: 大部分数据分析应用关注的功能: 用于