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 联 ...
随机推荐
- hdu2639(背包求第k优解)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2639 题意:给出一行价值,一行体积,让你在v体积的范围内找出第k大的值 分析:dp[i][j][k]表 ...
- hdu5124(树状数组+离散化)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5124 题意:有n条线段,求被覆盖到次数最多的点的次数 分析: 1.可以转化成求前缀和最大的问题:将区间 ...
- [置顶] Firefox OS 学习——manifest.webapp结构分析
在Firefox OS 学习——Gaia 编译分析 这篇文章多次提到manifest.webapp文件,对于做过android app 开发的人来说,都很熟悉Android.mk 和Manifest ...
- Linux Shell脚本入门--grep命令详解
grep简介<摘自鸟哥,并加以整理.> grep (global search regular expression(RE) and print out the line,全面搜索正则表达 ...
- Python每隔一秒钟打印当地时间
import threading,time global t def sayHello(): print time.strftime('%Y-%m-%d %H:%M:%S',time.localtim ...
- 单点更新线段树 RMQ
D. Xenia and Bit Operations time limit per test 2 seconds memory limit per test 256 megabytes input ...
- python学习1(小白记录)
python创建cocos2d-x项目注意点1. 2.7.5版本号的.配置好环境变量之后.要切换到tools文件夹下.直接运行 python create_project.py ..........这 ...
- H264相关随笔
DR(Instantaneous Decoding Refresh)--即时解码刷新. I和IDR帧都是使用帧内预测的.它们都是同一个东西而已,在编码和解码中为了方便,要首个I帧和其他I帧区别开,所以 ...
- Java 二次MD5 32位小写加密算法与php页面加密结果相同
最近做的一个项目需要使用MD5加密算法,需要加密的参数有两个.自己先试了几次,算的结果为php页面的不一样,后来与写php页面的同事沟通后,了解到php页面的算法如下: action = " ...
- Spring in action(Spring实战) 第四版中文翻译
第一部分 Spring核心 Spring提供了非常多功能,可是全部这些功能的基础是是依赖注入(DI)和面向方面编程(AOP). 第一章 Springing into action 本章包含: Spri ...