计算机网络(Ⅵ)应用层原理

一些网络应用的例子:

E-mail         Internaet电话

Web            电子支付

文本信息      搜索

P2P文件共享 流媒体

即时通讯      实时电视会议

.... ....

创建一个网络应用:

1.编程

2.在不同的端系统上运行。

网络应用的体系架构

可能的应用架构

1.客户-服务器模式(C/S:client/server)

2.对等模式(P2P:Peer To Peer)

2.混合体:客户-服务器模式+对等体系结构

C/S模式

服务器

1.一直在运行

2.固定的IP和周知的端口号

3.扩展性:服务器场

数据中心进行扩展

扩展性差

客户端

1.主动与服务器通讯

2.与互联网有间歇性连接

3.可能是动态的IP地址

4.不直接与其他客户端通信

注意:C/S模式随着用户数量的增加,性能断崖式下降!!!!(原因:以服务器为核心,服务器压力变大)

P2P模式

1.(几乎)没有一直运行的服务器

2.任意系统之间可以进行通信

3.每一个节点既是客户端,又是服务器

自扩展性-新peer节点带来新的服务能力,当然也带来新的服务需求

4.参与的主机间接性连接且可以改变IP地址

难以管理

混合体

进程通信

进程:在主机上运行的应用程序

1.在同一个主机内,使用进程间通信机制通信

2.不同主机,通过交换报文(Message)来通讯

        使用OS提供的通信服务

        按照应用同协议交换报文

        借助传输层提供的服务

注意:P2P架构的应用也有客户端进程和服务器进程之分

客户端进程:发起通讯的进程

服务器进程:等待连接的进程

 分布式进程的通讯需要解决的问题

 1.进程的标示和寻址问题(服务用户)

2.传输层-应用层提供服务是如何(服务)

位置:层间界面的SAP(TCP/IP:socket)
形式:应用程序接口API(TCP/IP:socket API)

 

 

 注:SDU(service data unit)服务数据单元。

3.如何使用传输层提供的服务,实现应用进程之间的报文交换,实现应用(用户使用服务)

定义应用层协议:报文格式,解释,时序等
编制程序,使用OS提供的API。调用网络基础设施提供通信服务传报文,实现应用时序等。

TCP之上的套字编程

对于使用面向连接服务(TCP)的应用而言,套接字是4元组的一个具有本地意义的标识

        4元组:(源IP,源port,目标IP,目标port

        唯一的指定了一个会话(2个进程之间的会话关系)

        应用使用这个标示,与远程的应用进程通信

        就像使用操作系统打开一个文件,OS返回一个文件句柄一样,以后使用这个文件句柄,而不是使用这个文件的目录名,文件名

        简单,便于管理

UDP之上的套字编程

UDP服务,两个进程之间的通讯之前无需建立连接

        每一个报文都是独立传输的

        前后报文可能给不同的分布式进程

因此,只能用一个整数表示本应用实体的表示

        因为这个报文可能传给另外一个分布式进程

穿过层间接口的信息大小最小

UDP socket:本IP,本端口

但是传输报文时:必须呀提供对方IP,port

        接收报文时:传输层需要上传对方的IP,port

对于使用无连接服务(UDP)的应用而言,套接字是二元组的一个具有本地意义的标示

2元组:IP,port(源端指定)

UDP套接字制定了应用所在的一个端节点(end point)

在发送数据报时,采用创建好的本地套接字(标示ID),就不必在发送每个报文中指明自己的ip和port

但是在发送报文时,必须要指定对方的ip和udp port(另外一个端节点)

Internet传输层提供的服务

TCP服务

可靠的通信服务

流量控制:发送放不会淹没接收方

拥塞控制:当网络出现拥塞时,能够抑制发送方

不能提供的服务:时间保证,最小吞吐量和安全

面向连接:要求客户端进程和服务器之间建立连接

UDP服务

不可靠数据传输

不提供的服务:可靠,流量控制,拥塞控制,时间,带宽保证,建立连接

UDP存在的理由

UDP通过增加端口号,实现进程到进程之间的连接

安全TCP

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/463235.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【调优方法】——warmup预热

文章目录 什么是warmup?为什么引入warmup?warmup策略1. 线性warmup(虚线)2. 指数warmup(点划线) warmup改进参考文献 什么是warmup? warmup是一种学习率预热的方法,是指在训练开始时使用较小的学习率&am…

【Java笔记】1-JDK/JRE/JVM是个啥?

JDK、JRE、JVM可以说是入门必须了解的三个词汇 先说全称 JDK:Java Development Kit,Java开发工具包 JRE:Java Runtime Environment,Java运行环境 JVM:Java Virtual Machine,Java虚拟机 再说关系 JVM⊆J…

阿里云docker安装禅道记录

docker network ls docker network create -d bridge cl_network sudo docker run --name zentao --restart always -p 9982:80 --networkcl_network -v /data/zentao:/data -e MYSQL_INTERNALtrue -d hub.zentao.net/app/zentao:18.5 参考:用docker安装禅道…

uniapp iOS打包证书过期——重新下载证书及更新文件

证书过期,重新生成步骤 关于所需的证书、标识符、描述文件等请查看iOS打包证书申请流程证书有效期为1年 过期提示 生成证书 点击 钥匙串访问 → 证书助理 → 从证书颁发机构请求证书 ; 我这里选择 存储到磁盘 ,邮件、名称 可自定义&#…

Pandas 数据清洗

1.数据清洗定义 数据清洗是对一些没有用的数据进行处理的过程。很多数据集存在数据缺失、数据格式错误、错误数据或重复数据的情况,如果要使数据分析更加准确,就需要对这些没有用的数据进行处理。 2.清洗空值 DataFrame.dropna(axis0, howany, threshN…

数据结构与算法(1)

一:文章总体结构内容解读 二:绪论 1.1研究: 1.范围 数据结构是一门研究非数值计算的程序设计中计算机的操作对象以及它们之间的关系和操作的学科; 2.计算机解决问题步骤: 1.2基本概念和术语: 1.数据、…

RNN与Self-Attention

文章目录 1. SimpleRNN1.1 h t h_t ht​计算1.2 激活函数 2. SimpleRNNSelf-Attention2.1 状态更新2.2 权重 α α α 1. SimpleRNN 学习视频:https://www.youtube.com/watch?vCc4ENs6BHQw&t0s 对于时序数据,输入输出都不固定,需要ma…

Vue指令:v-show、v-if

目录 1.v-show:频繁控制显示隐藏 v-if:要么显示&#xff0c;要么隐藏 2.网页渲染效果 3.flag:true 4.若flag:false&#xff0c;则 5.底层原理&#xff1a; 1.v-show:频繁控制显示隐藏 v-if:要么显示&#xff0c;要么隐藏 <!DOCTYPE html> <html lang"en&…

在Springboot中更好的打印日志

说明 我的系统缺乏一些日志打印,但我并不想显式的在我的业务代码中使用Slf4j注解,因为这会造成我无法关注我的业务代码逻辑,因为通常来说,10行业务代码 你可以就需要3-4行log.info来打印日志 是的,这样代码很难看,所以我使用了Aop 拦截器 面向对象 threadLoacl等技术来设计我…

进程间通信小练习

[!info] 编写程序 创建两个进程&#xff1a; 父进程执行文件拷贝操作。如果接收到SIGUSR1信号&#xff0c;将打印出当前拷贝进度。 子进程每隔一个固定时间向父进程发生SIGUSR1信号。 vi src.txt然后输几十个字 然后新建源程序 #include <stdio.h> #include <stdli…

NVR小程序接入平台/设备EasyNVR多个NVR同时管理多平台级联与上下级对接的高效应用

政务数据共享平台的建设正致力于消除“信息孤岛”现象&#xff0c;打破“数据烟囱”&#xff0c;实现国家、省、市及区县数据的全面对接与共享。省市平台的“级联对接”工作由多级平台共同构成&#xff0c;旨在满足跨部门、跨层级及跨省数据共享的需求&#xff0c;推动数据流通…

wait()方法和notify()方法

由于操作系统对线程的调度是随机执行的&#xff0c;且线程之间是抢占式执行的&#xff0c;因此线程之间执行的先后顺序难以预知。但是&#xff0c;有时候在实际开发中&#xff0c;我们希望合理的协调多个线程之间的先后执行顺序。在Java中&#xff0c;wait()方法和notify()方法…

搭建 EwoMail 邮件服务器

EwoMail简介 EwoMail是基于Linux的开源邮件服务器&#xff0c;支持一键搭建&#xff0c;集成了众多优秀稳定的组件&#xff0c;是一个快速部署、简单高效、安全稳定的邮件解决方案&#xff0c;支持电脑和手机的客户端&#xff0c;适合个人或邮箱功能需求少的企业。 非常稳定&…

ST算法解RMQ问题

题目 代码 #include <bits/stdc.h> using namespace std; const int N 2e510, M 20; int st[N][M]; int n, m; int main() {ios::sync_with_stdio(0);cin.tie(0);cin >> n;for(int i 1; i < n; i)cin >> st[i][0];for(int i 1; (1 << i) < …

STM32启动文件分析

1. 启动文件简介 启动文件由汇编编写&#xff0c;是系统上电复位后第一个执行的程序。主要做了以下工作&#xff1a; 初始化堆栈指针SP_initial_sp;初始化程序计数器指针PCReset_Handler;设置堆、栈的大小;初始化中断向量表;配置外部SRAM作为数据存储器&#xff08;这个由用户…

Netty 组件介绍 - Future Promise

在异步处理时&#xff0c;经常用到这两个接口 netty 中的 Future 继承 jdk 中的 FutuFuture&#xff0c;而Promise 又对 netty Future 进行了扩展。 idk Future 只能同步等待任务结束&#xff08;或成功或失败)才能得到结果netty Future 可以同步等待任务结束得到结也可以异…

破局智能制造:难点分析与对策

一、 智能制造过程中可能遇到难点: 1. --概念和技术繁多--: - 智能制造领域涉及众多概念和技术,如工业4.0、CPS、工业互联网等,让企业难以选择和应用。 2. --缺乏经验和成功案例--: - 企业在推进智能制造时缺乏经验,存在信息孤岛、自动化孤岛等问题,缺乏统一规划和系统推…

buuctf

就随便刷刷&#xff0c;就不写那么详细啦&#xff0c;就写写我的一些收获和不懂的地方啦 1. mb_substr($page&#xff0c;n&#xff0c;m)&#xff1a;返回page中从第n位开始&#xff0c;到nm位字符串的值 这个我觉得就是从第一个问号的地方开始截取&#xff0c;然后截到第二个…

AIGC实战——生成式人工智能总结与展望

AIGC实战——生成式人工智能总结与展望 0. 前言1. 生成式人工智能发展历程1.1 VAE 和 GAN 时代1.2 Transformer 时代1.3 大模型时代 2. 生成式 AI 的当前进展2.1 大语言模型2.2 文本生成代码模型2.3 文本生成图像模型2.4 其他应用 3. 生成式人工智能发展展望3.1 生成式 AI 在工…

分数阶傅里叶变换与信息熵怎么用于信号处理?

天马行空的理解与思考方式&#xff1a;分数阶傅里叶变换与信息熵怎么用于信号处理&#xff1f; ChiX-Y 快速学习&#xff0c;快速尝试&#xff0c;快速失败 已关注 35 人赞同了该文章 这篇文章希望能写的有趣&#xff0c;同时有质量&#xff0c;学习就是要多维度多角度&…