C/S通信模型和相关技术要点
差点儿全部的项目中,都会涉及到client和服务端。而client与server之间的通信又是一个非经常见但又有须要问题的技术问题。
首先,连接方式有长连接和短连接。先看看概念。
长连接短连接仅仅是一个概念性的问题,仅仅要知道其概念,不是一个特殊的东西:
长连接:系统通讯连接建立后就一直保持。
短连接:仅仅有系统须要相互发消息连接才建立(client发起),请求消息得到响应后连接关闭;
通讯实体间使用长连接,一般还须要定义心跳消息,定期发送来检測系统间链路是否异常,每隔一定时间发送一次心跳,假设一定次数没有收到心跳消息,这觉得此连接出现故障,须要断开连接又一次建立。
详细心跳消息的格式,以及发送间隔,以及多少次没有收到心跳就觉得链路异常,以及数据部是否算作心跳消息(有的系统假设接收到数据包则会清除心跳计时器也就相当于系统中的数据包也算作心跳消息);这个须要两端进行协商。比方GSM经常使用的短消息中心和其它网络实体互连的SMPP协议,要求建立的就是长连接。
非常显然,长连接要复杂些。对于服务端,要对连接上来的client进行管理,还要检查心跳包。非常多业务server都用的长连接,而接口server一般用短连接。
其次,数据的同步和异步请求。
在client请求到server后,client能够等待结果返回后,再处理其它的事情,也能够把请求放到队列,继续做其它的事情,有结果返回后,在做处理。这里就是同步和异步的问题。
一般来说,同步等待也是有个超时时间的,不能一直等待下去。而异步处理的话,都会有个消息队列和请求队列。当server的消息返回后,放到消息队列中,另外有一个线程来处理这个消息队列中的消息,以及和请求队列的数据做对应的处理。
另外,就是堵塞和非堵塞。
堵塞的结果就是这个线程将会等到这个结果返回,非堵塞就是仅仅发送请求,不等待结果。
在非常多时候,都会用异步和非堵塞,这样能够提高处理性能和资源的高效使用。
最后,就是报文。数据报文是自定义的。一般有2种:数据结构和xml数据。
这2种各有利弊。对于数据结构,程序内部处理比較easy,看在多版本号兼容方面没那么好,比方结构添加了字段,低版本号处理的时候,可能就有问题了。xml数据的兼容性比較好,你能够仅仅关心自己想要的字段,而不用管那些不关心的字段,所以对版本号的兼容也比較好。所以如今非常多都採用xml数据。而对xml数据,如今用的比較多的就是json,而且C++、java、android等都支持。另外就是在传输的过程中加密。当然了,对于跨平台,还要考虑字节序的问题。
最后,在总结一下:
1 连接方式:长连接和短连接。
2 数据的同步和异步请求。
3 堵塞和非堵塞。
4 报文:协议,加密,字节序。
转载请注明原创链接:http://blog.csdn.net/wujunokay/article/details/38211079
C/S通信模型和相关技术要点的更多相关文章
- SAAS相关技术要点
这篇文章本来是我们开发组内部用的一个小文档.因为我们公司以前没有做SAAS的经验,就成立了一个小组做一做这方面的技术前探,我是成员之一.这篇文档想从宏观的层面把开发一个SAAS应用所要用到的技术点稍微 ...
- WebGPU学习(五): 现代图形API技术要点和WebGPU支持情况调研
大家好,本文整理了现代图形API的技术要点,重点研究了并行和GPU Driven Render Pipeline相关的知识点,调查了WebGPU的相关支持情况. 另外,本文对实时光线追踪也进行了简要的 ...
- 【原】http缓存与cdn相关技术
摘要:最近要做这个主题的组内分享,所以准备了一个星期,查了比较多的资料.准备的过程虽然很烦很耗时间,不过因为需要查很多的资料,因此整个过程下来,对这方面的知识影响更加深刻.来来来,接下来总结总结 一 ...
- React.js 常用技术要点
最近在公司的一个移动端WEB产品中使用了React这个框架(并不是React-Native),记录一下在开发过程中遇到的各种问题以及对应的解决方法,希望能对读者有所帮助. React原则 React不 ...
- http缓存与cdn相关技术
阅读目录 一 http缓存 二.Http缓存概念解析 三.cdn相关技术 摘要:最近要做这个主题的组内分享,所以准备了一个星期,查了比较多的资料.准备的过程虽然很烦很耗时间,不过因为需要查很多的资料, ...
- Excel阅读模式/单元格行列指示/聚光灯开发 技术要点再分享
1. 引言 文题中所谓技术要点再分享,本意是想在大神Charltsing Liu的博文“简单介绍Excel单元格行列指示的实现原理(俗称聚光灯功能)”的基础上写一点个人开发体会.写本文的初衷有三点,一 ...
- Java程序员需要突破的技术要点
一.源码分析 源码分析是一种临界知识,掌握了这种临界知识,能不变应万变,源码分析对于很多人来说很枯燥,生涩难懂. 源码阅读,我觉得最核心有三点:技术基础+强烈的求知欲+耐心. 我认为是阅读源码的最核心 ...
- 腾讯架构师分享的Java程序员需要突破的技术要点
一.源码分析 源码分析是一种临界知识,掌握了这种临界知识,能不变应万变,源码分析对于很多人来说很枯燥,生涩难懂. 源码阅读,我觉得最核心有三点:技术基础+强烈的求知欲+耐心. 我认为是阅读源码的最核心 ...
- 混合事务分析处理“HTAP”的技术要点分析
HTAP是近些年来比较火的一个概念,本文将聊聊HTAP的前世今生及技术特点. 一.数据应用类别 根据数据的使用特征,可简单做如下划分.在选择技术平台之前,我们需要做好这样的定位. 1.1 OLTP 联 ...
随机推荐
- 【C#遗补】获取应用程序路径之System.IO.Directory.GetCurrentDirectory和System.Windows.Forms.Application.StartupPath的区别
原文:[C#遗补]获取应用程序路径之System.IO.Directory.GetCurrentDirectory和System.Windows.Forms.Application.StartupPa ...
- android maven eclipse里面新建mavenprojectThe desired archetype does not exist
这个问题头疼死我了 又一次配置下你看我的教程 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2hlbmFpbmkxMTk=/font/5a6L5L2T/f ...
- qt的资源替换搜索QDir具体解释
QDir对跨平台的文件夹操作提供了非常多的便利,为了更加方便的提供全局资源的查找,QDir提供了搜索路径替换功能,攻克了资源搜索不便的问题,也能提高文件查找的效率. QDir通过已知的路径前缀去搜索并 ...
- windows phone (20) Image元素
原文:windows phone (20) Image元素 之前有说道wp目前支持的图片格式为png和jpeg ,我们可以通过设置Source属性设置图片源,下面要说的是Iamge元素的部分属性,这就 ...
- == 和 equal
==比较是地址 equal比较的是值 Integer r1 = new Integer(900);//定义r1整型对象 Integer r2 = new Integer(900);//定义r2整型对象 ...
- WCF异常传播
传送至客户端的异常肯定是CommunitionException类型,包括一般的通信过程中出错而引发的CommunicationException类型,System.IdentityModel.Sel ...
- ASM时的OFM特性对影的建数据文件名称的影响及为SYSTEM表空间的数据文件使用别名
客户遇到个DG的问题,存储使用的ASM管理,有多个磁盘盘. 在主库创建数据文件,备库自己主动创建的数据文件都在同一磁盘组,而且在主库创建数据文件是指定的是类似**.DBF的名字,到备库也变成了使用AS ...
- 使用gSoap规避和改动ONVIF标准类型结构的解析
ONVIF/gSoap依赖关系及问题 ONVIF是一组服务规范,标准參考 gSoap是一套基于实现SOAP通信接口的工具链 即是,当我们须要訪问ONVIF的Web Service或实现对ONVIF部分 ...
- jQuery Ajax: $.post请求示例
jQuery Ajax: $.post请求示例 leyangjun.html页面 <html> <head> <meta http-equiv="Content ...
- Hdu 5073 Galaxy 精度问题
思路: 其实求解很简单直接说解法,移动K个后 上下的角动量最小,能肯定是相连的(n-k)个,至于为什么 你自己好好想想(easy): 对于一些等质量的质点中心在 所在位置和除以点的个数 average ...