通信接口是webservice快还是scoket快解决方案
通信接口是webservice快还是scoket快
webservice和scoket都可以做为通信接口,一个走HTTP访问,一个走TCP协议访问
问1:
通讯速度是webservice快还是scoket快
问2:
并发数量是webservice大还是scoket大
问3:
大数据包是webservice合适还是scoket更合适
以上一个问题15分,先谢谢各位回复,回复得好,还会给贴加分!
------解决方案--------------------
apache的mina2.0对scoket做了封装和实现,据说是高性能,高并发。没在实际项目中使用过,给你提供点参考信息。
------解决方案--------------------
肯定是 Socket 快了!
WebServices 是建立在 HTTP 基础之上的,而 HTTP 是建立在 TCP 基础上的。也就是说 WebServices 在 TCP 基础上包装了两层!
但是,直接使用 TCP Socket 的话速度是快了,但是出错的几率,以及开发难度成数倍地增加了。Socket 通信的话,你还得自己设计通信协议,光这点就很复杂。
------解决方案--------------------
WS封装的层数多点,肯定Socket快。
------解决方案--------------------
问题2和问题3都是和问题1一样,Socket好些。
因为WS需要在HTTP协议上传信息,包的尺寸就会大些。大数据量,这个影响就明显些。
而因为多了些marshal/unmarshal的步骤,所以WS占CPU的资源肯定大些,同硬件配置下自然通量低些。
但使用Socket的确有问题,2楼有说,不重复了。
------解决方案--------------------
学习。
个 人觉得,WS果断比自己写个协议成熟。除非企业要求高。
------解决方案--------------------
超底层越麻烦!
------解决方案--------------------
对于楼主的前两个问题,现在java都有对此非常好的支持与封装,单从这两种技术上来讲速度,以现在的机器硬件可以忽略不计。实际项目中的性能更多的是去关注你的程序的设计架构和稳定性,而不是你的程序在将处理完后的数据交给底层用哪种方式进行网络传输时的性能消耗。
当然如果楼主你们的目标项目是类似于视频系统,会有巨大的网络数据传输,那就另当别论了。但一般的商业项目,只是通信一些商业数据和用户数据的话,很有可能一个网络报文过来你这一个线程需要花费好几秒的时间来做处理,然后不到一秒的时间就从socket或者web service端口将处理后的信息发送出去了(如果网络状况良好的话)。
所以第一个问题,通信速度,底层都是TCP连接,都需要进行三次握手才能建立连接,只要你的网络状况良好,这个性能消耗是不需要上层应用程序去考虑的,否则的话那我们现在用的所有TCP通信的软件岂不是都非常的消耗性能了。
第二个问题,这两种技术都支持多线程并发,这个几乎全部取决于你的多线程架构是否良好,跟底层的关系应该不是很大。顶多在一些比较少见的情况考虑一下直接使用TCP协议和web service在底层上的一些差异。不过对于服务端的ServerSocket,需要考虑是需要进行长连接还是短连接的问题。web service是建立在HTTP基础上的,底层全部都是封装好的,不需要你去考虑底层通信的细节。而且基于HTTP上层,web service本身还有很多种协议可供选择。
第三个问题,大数据包的话,比如说视频网站之类的,具体可以参考下这个领域的一些资料,什么断点续传,P2P协议支持等等,毕竟大多数的J2EE商业领域都还是以传输一些商业数据和用户数据居多。
简单发表了一下个人看法。不过顺带说一句,现在的大趋势已经逐渐走向SOA架构了,所以肯定是web service越来越受欢迎,在网络上跨平台调用你的服务就像你在程序里调用底层封装好的一个API方法一样简单。如果是基于socket,别人想要调用你的服务,还得专门写一个支持你这个socket接口的Adapter。
------解决方案--------------------
探讨
肯定是 Socket 快了!
WebServices 是建立在 HTTP 基础之上的,而 HTTP 是建立在 TCP 基础上的。也就是说 WebServices 在 TCP 基础上包装了两层!
但是,直接使用 TCP Socket 的话速度是快了,但是出错的几率,以及开发难度成数倍地增加了。Socket 通信的话,你还得自己设计通信协议,光这点就很复杂。
------解决方案--------------------
问1:
通讯速度是webservice快还是scoket快
Socket快出很多(不需要解析XML、不需要传递大量重复的XML标记)
问2:
并发数量是webservice大还是scoket大
web service的并发数等于服务器的并发数,可以做服务器集群,Socket集群比较复杂(服务器间通信复杂),
问3:
大数据包是webservice合适还是scoket更合适
大数据包Socket合适些Webservice可以自己制订报文然后压缩传输效率也不错, 或者可以考虑 Tuxedo 、EJB、
通信接口是webservice快还是scoket快解决方案的更多相关文章
- 【转】TCP拥塞控制,慢启动、拥塞避免、快重传以及快恢复
转自:http://blog.csdn.net/yusiguyuan/article/details/22847787 注:本文绝大部分是来自转载的博客,还补充了少量内容. 一.TCP的拥塞控制 拥塞 ...
- TCP超时重传、滑动窗口、拥塞控制、快重传和快恢复
TCP超时重传 原理是在发送某一个数据以后就开启一个计时器,在一定时间内如果没有得到发送的数据报的ACK报文,那么就重新发送数据,直到发送成功为止. 影响超时重传机制协议效率的一个关键参数是重传超时时 ...
- TCP/IP学习笔记18--TCP--拥塞控制 (慢开始, 拥塞避免, 快重传和快恢复)
用最多的梦面对未来 -- 李嘉诚 在某段时间,若对网络资源的需求超过了该资源所能提供 ...
- 计算机网络传输层之TCP拥塞控制(慢开始与拥塞避免、快重传和快恢复)
文章转自:https://blog.csdn.net/weixin_43914604/article/details/105532044 学习课程:<2019王道考研计算机网络> 学习目的 ...
- 先贴上代码:Random快排,快排的非递归实现
设要排序的数组是A[0]……A[N-1],首先任意选取一个数据(通常选用数组的第一个数)作为主元,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序.值得注意的是, ...
- 快还要更快,让PHP 7 运行更加神速
导读 PHP 7 比5.x 快上很多,即使只有单纯的版本升级就已经很有感,不过大家还是希望它变得越来越快,这时再做些小调整就会更有fu,Let's try it! 事前准备 说到PHP 7,那一定跑不 ...
- TCP拥塞控制-慢启动、拥塞避免、快重传、快启动
一般原理:发生拥塞控制的原因:资源(带宽.交换节点的缓存.处理机)的需求>可用资源. 作用:拥塞控制就是为了防止过多的数据注入到网络中,这样可以使网络中的路由器或者链路不至于过载.拥塞控制要做的 ...
- 前端通信:ajax设计方案(八)--- 设计请求池,复用请求,让前端通信快、更快、再快一点
直接进入主题,本篇文章有点长,包括从设计阶段,到摸索阶段,再到实现阶段,最后全面覆盖测试阶段(包括数据搜集清洗),还有与主流前端通信框架进行对比PK阶段. 首先介绍一下一些概念: 1. 浏览器的并发能 ...
- c++快读与快输模板
快读 inline int read() { ; ; char ch=getchar(); ; ch=getchar();} )+(X<<)+ch-'; ch=getchar();} if ...
随机推荐
- 阶段3 2.Spring_10.Spring中事务控制_3 作业-基于注解的AOP实现事务控制及问题分析_下
此时没有异常 测试我们的方法 执行报错 注解在实际的测试过程中,实际的执行顺序是有问题的.会先调用最终通知.然后再调用后置通知 最终通知已经关闭了连接.再调用后置通知肯定报错. getThreadCo ...
- fiddler抓取app的https的包
线上问题的排查有时候需要抓包,但是是https协议的,则需要安装证书 在Android 6.0 (API level 23)及以前,APP默认信任系统自带的CA证书以及用于导入的CA证书,Androi ...
- sorted&filter&map
python里列表的sort和内置的sorted函数,都可以进行排序,列表的sort方法是在原有的列表上进行排序,sorted是会返回一个新的对象 persons = [ {'name': '小明', ...
- Doker部署Jmeter(一) 目标服务器部署Jmeter监控容器
用jmeter插件监控服务器性能之前也有提到:https://www.cnblogs.com/betterbb/p/11285022.html 这里主要记录一下docker上的部署,所需的3个插件可以 ...
- 手写朴素贝叶斯(naive_bayes)分类算法
朴素贝叶斯假设各属性间相互独立,直接从已有样本中计算各种概率,以贝叶斯方程推导出预测样本的分类. 为了处理预测时样本的(类别,属性值)对未在训练样本出现,从而导致概率为0的情况,使用拉普拉斯修正(假设 ...
- TensorFlow学习笔记0-安装TensorFlow环境
TensorFlow学习笔记0-安装TensorFlow环境 作者: YunYuan 转载请注明来源,谢谢! 写在前面 系统: Windows Enterprise 10 x64 CPU:Intel( ...
- 查看主机CPU信息
一.关于CPU的几个概念 CPU的作用 计算机中的中央处理单元(CPU)执行基本的计算工作 -- 运行程序.但是,一个单核的CPU同一时间只能一次执行一个任务,为了提高计算机的处理能力,也就出现了多C ...
- kubernetes集群node加入不了master错误处理
#如果node加入不了master或者加入成功但是,在master中显示不出来.排查错误:1. 运行,kubelet, 查看日志,一般是kubelet的运行和docker启动方式不匹配.调整:vim ...
- HDU 1114 Piggy-Bank(动态规划、完全背包)
Piggy-Bank Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- etcd集群添加节点
查看当前集群节点信息 # etcdctl member list --write-out=table +------------------+---------+------------------- ...