免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: 小尾巴鱼
打印 上一主题 下一主题

[其它] 模拟12306购票系统的处理多用户购票网络编程(已公布获奖) [复制链接]

论坛徽章:
32
CU大牛徽章
日期:2013-05-20 10:45:13每日论坛发贴之星
日期:2015-09-07 06:20:00每日论坛发贴之星
日期:2015-09-07 06:20:00数据库技术版块每日发帖之星
日期:2015-12-13 06:20:0015-16赛季CBA联赛之江苏
日期:2016-03-03 11:56:13IT运维版块每日发帖之星
日期:2016-03-06 06:20:00fulanqi
日期:2016-06-17 17:54:25IT运维版块每日发帖之星
日期:2016-07-23 06:20:0015-16赛季CBA联赛之佛山
日期:2016-08-11 18:06:41JAVA
日期:2016-10-25 16:09:072017金鸡报晓
日期:2017-01-10 15:13:292017金鸡报晓
日期:2017-02-08 10:33:21
1 [报告]
发表于 2015-07-28 09:55 |显示全部楼层
1. 很多用户登录服务器是协议用TCP还是UDP?
用TCP协议或UDP协议都可以,主要还是取决于实际的需求。
UDP提供了不可靠、不保证数据包的有序性的端到端的数据传输服务,要使其可靠,需要在UDP协议上构建自己的协议,比如RUDP(Reliable User Datagram Protocol)可靠用户数据报协议。
以12306购票系统为例,如果客户端限定为Android和iOS,那么采用UDP作为通信协议是可行的(也可以选择TCP)。因为客户端(Android和iOS)是自行开发的,协议可控,服务器端也是自行开发的。
但是12306购票系统的实际情况没有那么简单,客户端还有PC的浏览器,浏览器默认是使用HTTP/HTTPS协议访问的,而HTTP协议构建于TCP协议之上,这就要求服务器端至少需要支持TCP协议,所以为了简化服务器端的开发难度,应选择TCP协议,没必要同时开发TCP和UDP两套通信机制。
故协议确定使用TCP。

2. 如果用UDP如何解决数据的不安全性,
要保证UDP协议的数据安全性问题,可以考虑UDT协议,即UDP-based Data Transfer Protocol,基于UDP的数据传输协议。
引用百科的解释,UDT是一种互联网数据传输协议。UDT的主要目的是支持高速广域网上的海量数据传输,而互联网上的标准数据传输协议TCP在高带宽长距离网络上性能很差。顾名思义,UDT建于UDP之上,并引入新的拥塞控制和数据可靠性控制机制。UDT是面向连接的双向的应用层协议。它同时支持可靠的数据流传输和部分可靠的数据报传输。由于UDT完全在UDP上实现,它也可以应用在除了高速数据传输之外的其它应用领域,例如点到点技术(P2P),防火墙穿透,多媒体数据传输等等。
其次就是考虑引入加密算法,对称加密或非对称加密,把传输的数据进行加密。

3. 如果用TCP如何解决占用大量网络资源造成网络阻塞的问题。
这个问题相关的因素有很多:机房的带宽、网络设施、负载均衡/反向代理、应用服务器集群等。
单从TCP协议本身来讲,是解决不了网络阻塞的问题。
找出引起网络阻塞的瓶颈,解决它。
如果是Nginx反向代理,后端连接多台应用服务器,Nginx负载达到瓶颈了,那么可以用多台Nginx,通过智能DNS分配访问。或者是改为使用硬件负载均衡,连接多台应用服务器。
……
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP