文章目录
- 客户-服务器模型与并发处理
-
- 了解分布式应用的基本概念
- 应用层协议
- 客户—服务器模型的术语和概念
- 服务器并发处理
-
- 服务器创建并发进程
- 并发的原理——时间分片
- 并发和异步I/O
- 欢迎来我的个人博客 站??[www.liangyuanshao.top](http://www.liangyuanshao.top/)
客户-服务器模型与并发处理
了解分布式应用的基本概念
分布式计算的概率:提供一个透明的环境,隐藏计算机和服务的地理位置
分布式应用就是在分布式计算的基础之上完成的应用程序,软件设计人员必须掌握设计和实现分布式应用程序时相关的原则和技术
应用层协议
在TCP/IP的一些更底层协议基础上,设计的一些用于特定的应用协议。比如说,要开发一个新软件,我就自定义了一个协议用于该软件的信息通信
TCP/IP包含了许多标准应用协议,如:文件传送、远程登陆、电子邮件等
客户—服务器模型的术语和概念
该模型的设计之初就是为了解决**“会聚点问题”**:人工分别启动两台独立机器上的两个程序,并让其通信问题
客户—服务器模型,顾名思义就是 络中的端系统分为了客户和服务器两个角色,它要求服务器进行通信的应用进程中,必须在启动执行后(无期限地)等待客户与其联系
下面是一些比较重要的概念
-
服务器的设计与实现更加的困难,主要由于其 特权和复杂性
特权是因为服务器软件要访问受OS保护的对象,因此服务器软件的执行需要一些系统特权-
鉴别-验证用户身份
-
授权-允许客户访问服务器提供的服务
-
数据安全-确保数据不被无意泄漏或损坏
-
保密-防止未经授权访问信息
-
保护-确保 络应用程序不滥用系统资源
-
-
标准和非标准客户软件
应用程序可以调用标准的TCP/IP服务,也可以调用自定义的服务,将服务器-客户模型下的程序分为了标准和非标准客户软件 -
服务的参数化
允许用户指明协议端口 的软件,将服务器的服务,区分到了端口上,比如说79端口提供时间服务等等 -
无连接和面向连接的服务器
络层分为采用TCP面向连接的服务,还是UDP无连接的服务 -
有状态和无状态服务器
状态信息:服务器维护的与客户交互的活动信息
服务器如果有状态,就会记录之前的客户发来的信息,如果没有状态就不会记录。换言之,客户所有请求的 文都不依赖之前发送的 文,就是无状态的服务器,反之,服务器就是有状态的 -
标识客户(在有状态服务器的基础上)
有状态服务器记录(标识)客户信息,常用有两种方法,端点和句柄。端点就是客户的ip和端口,这个有时会经常改变,所以作为客户表示不可靠
句柄,类似session,服务器内部用一个整数来标识客户
-
有限状态
有状态服务器不可能永远维持状态,有状态的应用协议需要终止 -
有状态服务器和无状态服务器设计的复杂性
有状态服务器在实际互联 中,机器可能崩溃或重启,而 文可能丢失、重复或乱序。采用有状态的设计会导致复杂的应用协议,而这种应用协议难于设计、理解和正确实现只有当应用协议被设计成对操作是幂等的,服务器才能是无状态的,因为无状态的服务器不依赖客户之前发送的 文
2022.3.7更新
服务器并发处理
服务器中的并发
一个进程只能执行它最开始编译的程序,不能改变的话,对服务器来说意义非常小,所以操心系统提供了一个方法,可以用新程序的代码来代替当前正在执行的进程所运行的代码,该调用不影响其他进程,系统调用方法是execve
Execve对于需要处理不同服务的服务器而言特别重要,只要将不同服务的代码相互分开,就能将每种服务作为一个独立的程序进行构建、编写和编译,它和fork()地位差不多
并发的原理——时间分片
时间分片(timeslicing)机制试图在所有线程间平均分配可用的处理器资源,当多个并发线程共享可用的CPU时,系统采用时间分片机制实现并发
时间分片设计原则:在协议设计时,应将上下文切换次数降到最低程序设计人员应根据需要选择服务器软件的并发算法使得并发处理带来的好处大于上下文切换的开销
并发和异步I/O
关于异步这个概率就不详细解释了,就提一下,异步I/O能够实现并发
欢迎来我的个人博客 站??www.liangyuanshao.top
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!