套接字网络编程基础(一)

网络编程相关基本概念

进程与线程

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。它可以申请和拥有系统资源,是一个动态的概念,是一个活动的实体

进程的概念主要有两点:第一,进程是一个实体。每一个进程都有它自己的地址空间,一般情况下,包括文本区域(text region)、数据区域(data region)和堆栈(stack region)。文本区域存储处理器执行的代码;数据区域存储变量和进程执行期间使用的动态分配的内存;堆栈区域存储着活动过程调用的指令和本地变量。第二,进程是一个“执行中的程序”。程序是一个没有生命的实体,只有处理器赋予程序生命时(操作系统执行之),它才能成为一个活动的实体,称其为进程。进程是有一定生命期的

进程和线程关系:
通常在一个进程中可以包含若干个线程,它们可以利用进程所拥有的资源,在引入线程的操作系统中,通常都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位,由于线程比进程更小,基本上不拥有系统资源,故对它的调度所付出的开销就会小得多,能更高效的提高系统内多个程序间并发执行的程度

当创建一个进程时,系统会自动创建它的第一个线程,称为主线程。然后,该线程可以创建其他的线程,而这些线程又能创建更多的线程

这里写图片描述

网络应用程序

这里写图片描述

从计算机网络体系结构的角度来看,网络应用处于网络层次的最上层。

从功能上可以将网络应用程序分为两部分。一部分是专门负责网络通信的模块,它们与网络协议栈相连接,借助网络协议栈提供的服务完成网络上数据信息的交换;另一部分是面向用户或者进行其他处理的模块,它们接收用户的命令,或者借助网络传输过来的数据进行加工。这两部分模块相互配合,来实现网络程序的功能。

网络编程首先要解决网间进程通信的问题,然后才能在通信的基础上开发应用功能。

实现网间进程通信必须解决的问题

  • 网间进程的标识问题
  • 与网络协议栈连接问题
  • 多重协议的识别问题
  • 不同通信服务的问题

Internet中网间进程通信

这里写图片描述

网间进程通信是指网络中不同主机中的应用进程之间的相互通信。

对于Internet中网间进程通信主要是对TCP/IP协议栈的应用,因为Internet是基于TCP/IP协议栈的。实现网络中应用进程之间的通信对于网络协议栈来说,是在发送端自上而下地复用,在接收端自下而上的分用

其中,传输层在网络通信中占据重要地位。传输层是对计算机网络中通信主机内部进行独立操作的第一层,是支持端到端的进程通信的关键一层。TCP/IP提出了传输层协议端口(Protocol Port,端口)的概念,解决了通信进程的标识问题

网络层的IP在Internet中也起着重要作用,使用IP地址统一了Internet中的各种主机的物理地址,用IP数据报统一了各种物理网的帧,实现了异构网的互连

端口

端口是TCP/IP协议簇中,应用层进程与传输层协议实体间的通信接口。应用层进程通过系统调用与某个端口进行绑定,之后通过这个端口与其它网络进程进行数据交换

类似于文件描述符,每个端口都拥有一个叫作端口号(Port Number)的整数型标识符,用于区别不同的端口

端口是操作系统可分配的一种资源;从实现角度来看,端口是一种抽象的软件机制,包括一些数据结构和I/O缓冲区

进程的标识

在Internet中,用一个三元组可以在全局中唯一地标识一个应用层进程:
应用层程序 = (传输层协议、主机IP地址、传输层的端口号)
这样一个三元组,叫做一个半相关,它标识了Internet中进程间通信的一个端点

网间进程通信的标识

一个完整的网间通信需要一个无援助在全局中唯一地标识:
(传输层协议、本地机IP地址、本地机传输层端口端口、远地机IP地址、远地机传输层端口)

这个五元组称为一个全相关,即两个协议相同的半相关才能组合成一个合适的全相关,或完全指定一对网间通信的进程

网络协议的特征###

面向消息的协议与基于流的协议

**面向消息的协议:**面向消息的协议以消息为单位在网上传送数据,消息在发送端一条一条地发送,在接收端也只能一条一条地接收,每条消息是独立的,消息之间存在边界

**基于流的协议:**基于流的协议不保护消息边界,将数据当作字节流连续地传输,不管实际边界是否存在。如果发送端连续发送数据,接收端有可能在一次接收动作中接收两个或者更多的数据包。在发送端,允许系统将原始消息分解成几条小消息分别发送,或者把几条消息积累在一起,形成一个较大的数据包,一次送出。多次发送的数据统一编号,从而把它们联系在一起。接收端会尽量地读取有效数据。只要数据一到达,网络堆栈就开始读取它,并将它缓存下来等待进程处理。在进程读取数据时,系统尽量返回更多的数据

**保护消息边界:**传输协议把数据当作一条独立的消息在网络上传输,接收端只能接收独立的消息。存在保护消息边界,接收端一次只能接收发送端发出的一个数据包

面向连接的服务和无连接的服务

面向连接的服务是电话系统服务模式的抽象,即每一次完整的数据传输都要经过建立连接、使用连接和终止连接的过程。在数据传输的过程中,各数据分组不携带目的地址,而使用连接号(Connect ID)。本质上,连接是一个管道,收发数据不但顺序一致,而且内容相同

无连接服务是邮政系统服务的抽象,每个分组都携带完整的目的地址,各分组在系统中独立传送。无连接服务不能保证分组到达的先后顺序,不进行分组出错的恢复与重传,不保证传输的可靠性。无连接协议在通信前,不需要建立连接,也不管接收端是否正在准备接收。

可靠性和次序性

可靠性保证保证了发送端发出的每个字节都能到达既定的接收端,不出错,保证数据的完整性,称为保证投递。

次序性是指对数据到达接收端的顺序进行处理。保护次序性的协议保证接收端收到数据的顺序就是数据的发送顺序,称为按序递交。

可靠性和次序性与协议是否是面向连接密切联系,多数情况下,面向连接的协议做了许多工作能确保数据的可靠性和次序性。而无连接的协议不必去验证数据的完整性,不必确认收到的数据,不必考虑数据的次序,因而简单快速的多。

//以上内容大部分摘自《网络编程实用教程(第三版)》 编者 段利国 刘金江 倪天伟 叶树华
//侵权必删
//仅供参考
//windows网络编程

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值