【网络编程】第2章(1) 客户-服务器模型与并发处理

简介: 【网络编程】第2章(1) 客户-服务器模型与并发处理

客户-服务器模型与并发处理

了解分布式应用的基本概念

分布式计算的概率:提供一个透明的环境,隐藏计算机和服务的地理位置


分布式应用就是在分布式计算的基础之上完成的应用程序,软件设计人员必须掌握设计和实现分布式应用程序时相关的原则和技术


应用层协议

在TCP/IP的一些更底层协议基础上,设计的一些用于特定的应用协议。比如说,要开发一个新软件,我就自定义了一个协议用于该软件的信息通信


TCP/IP包含了许多标准应用协议,如:文件传送、远程登陆、电子邮件等


客户—服务器模型的术语和概念

该模型的设计之初就是为了解决“会聚点问题”:人工分别启动两台独立机器上的两个程序,并让其通信问题


客户—服务器模型,顾名思义就是网络中的端系统分为了客户和服务器两个角色,它要求服务器进行通信的应用进程中,必须在启动执行后(无期限地)等待客户与其联系


下面是一些比较重要的概念


1.服务器的设计与实现更加的困难,主要由于其 特权和复杂性

特权是因为服务器软件要访问受OS保护的对象,因此服务器软件的执行需要一些系统特权


鉴别-验证用户身份


授权-允许客户访问服务器提供的服务


数据安全-确保数据不被无意泄漏或损坏


保密-防止未经授权访问信息


保护-确保网络应用程序不滥用系统资源


2.标准和非标准客户软件

应用程序可以调用标准的TCP/IP服务,也可以调用自定义的服务,将服务器-客户模型下的程序分为了标准和非标准客户软件


3.服务的参数化

允许用户指明协议端口号的软件,将服务器的服务,区分到了端口上,比如说79端口提供时间服务等等


4.无连接和面向连接的服务器

网络层分为采用TCP面向连接的服务,还是UDP无连接的服务


5.有状态和无状态服务器

状态信息:服务器维护的与客户交互的活动信息

服务器如果有状态,就会记录之前的客户发来的信息,如果没有状态就不会记录。换言之,客户所有请求的报文都不依赖之前发送的报文,就是无状态的服务器,反之,服务器就是有状态的


6.标识客户(在有状态服务器的基础上)

有状态服务器记录(标识)客户信息,常用有两种方法,端点和句柄。


端点就是客户的ip和端口,这个有时会经常改变,所以作为客户表示不可靠


句柄,类似session,服务器内部用一个整数来标识客户


7.有限状态

有状态服务器不可能永远维持状态,有状态的应用协议需要终止


8.有状态服务器和无状态服务器设计的复杂性

有状态服务器在实际互联网中,机器可能崩溃或重启,而报文可能丢失、重复或乱序。采用有状态的设计会导致复杂的应用协议,而这种应用协议难于设计、理解和正确实现


只有当应用协议被设计成对操作是幂等的,服务器才能是无状态的,因为无状态的服务器不依赖客户之前发送的报文


服务器并发处理

还没讲


相关文章
|
3月前
|
存储 人工智能 边缘计算
当 AI 进入「算力密集时代」:你的服务器能跑通大模型吗?
本文深入探讨AI服务器在技术落地中的核心瓶颈问题,结合实战经验解析从模型训练到端侧部署的算力优化策略。内容涵盖三大典型场景的算力需求差异、GPU服务器选型的五大反直觉真相、实战优化方法(如混合精度训练与硬件资源监控),以及边缘AI部署挑战和解决方案。同时提供算力弹性扩展策略、模型生命周期管理及合规性建议,帮助读者构建可持续发展的算力体系。文末附有获取更多资源的指引。
174 17
|
2月前
|
调度 Python
探索Python高级并发与网络编程技术。
可以看出,Python的高级并发和网络编程极具挑战,却也饱含乐趣。探索这些技术,你将会发现:它们好比是Python世界的海洋,有穿越风暴的波涛,也有寂静深海的奇妙。开始旅途,探索无尽可能吧!
64 15
|
3月前
|
存储 弹性计算 测试技术
10分钟私有部署QwQ-32B模型,像购买Ecs实例一样快捷
虽然阿里云提供了基于 IaaS 部署 QwQ-32B 模型的方式,但传统的基于IaaS的部署方式需要用户自行配置环境、安装依赖、优化硬件资源,并解决复杂的网络与存储问题,整个流程不仅耗时耗力,还容易因操作失误导致各种不可预见的问题。 因此,阿里云计算巢提供了基于ECS镜像与VLLM的大模型一键部署方案,通过ECS镜像打包标准环境,通过Ros模版实现云资源与大模型的一键部署,用户无需关心模型部署运行的标准环境与底层云资源编排,10分钟即可部署使用QwQ-32B模型,15分钟即可部署使用Deepseek-R1-70B模型。
|
5月前
|
人工智能 负载均衡 数据可视化
阿里云出手了,DeepSeek服务器拒绝繁忙,免费部署DeepSeek模型671B满血版
阿里云推出免费部署DeepSeek模型671B满血版服务,通过百炼大模型平台,用户无需编码,最快5分钟、最低0元即可完成部署。平台提供100万免费Token,支持DeepSeek-R1和DeepSeek-V3等多款模型调用,有效解决服务器繁忙问题。新手零基础也能轻松上手,享受高效稳定的API调用和自动弹性扩展功能。教程涵盖开通服务、获取API-KEY及配置Chatbox客户端等步骤,详细指引助您快速实现DeepSeek自由。
381 18
|
4月前
|
运维 容灾 API
云栖大会 | 阿里云网络持续演进之路:简单易用的智能云网络,让客户专注业务创新
云栖大会 | 阿里云网络持续演进之路:简单易用的智能云网络,让客户专注业务创新
157 2
|
4月前
|
人工智能 运维 API
第七届 SD-WAN&SASE大会暨云网络大会 | 简单易用的智能云网络,让客户专注业务创新
第七届 SD-WAN&SASE大会暨云网络大会 | 简单易用的智能云网络,让客户专注业务创新
|
9月前
|
数据可视化 Linux 网络安全
如何使用服务器训练模型
本文介绍了如何使用服务器训练模型,包括获取服务器、访问服务器、上传文件、配置环境、训练模型和下载模型等步骤。适合没有GPU或不熟悉Linux服务器的用户。通过MobaXterm工具连接服务器,使用Conda管理环境,确保训练过程顺利进行。
766 0
如何使用服务器训练模型
|
10月前
|
存储 机器人 Linux
Netty(二)-服务端网络编程常见网络IO模型讲解
Netty(二)-服务端网络编程常见网络IO模型讲解
|
10月前
|
网络协议 C语言
C语言 网络编程(十三)并发的TCP服务端-以进程完成功能
这段代码实现了一个基于TCP协议的多进程并发服务端和客户端程序。服务端通过创建子进程来处理多个客户端连接,解决了粘包问题,并支持不定长数据传输。客户端则循环发送数据并接收服务端回传的信息,同样处理了粘包问题。程序通过自定义的数据长度前缀确保了数据的完整性和准确性。
|
9月前
|
存储 PyTorch API
NVIDIA Triton系列09-为服务器添加模型
本文介绍了如何为NVIDIA Triton模型仓库添加新模型。通过示例模型`inception_graphdef`的配置文件`config.pbtxt`,详细解释了模型名称、平台/后端名称、模型执行策略、最大批量值、输入输出节点及版本策略等配置项。内容涵盖了模型的基本要素和配置细节,帮助读者更好地理解和使用Triton服务器。
102 0