套接字(linux相关)

 

前言:略

一、前因

  一切从tcp、udp开始。

  众所周知,网络模型一般有两种模型,一种为OSI概念模型(七层),另一种为TCP/IP网络模型(四层)。

  TCP/IP应用层对应OSI的应用层、显示层、会话层;TCP、UDP对应传输层;互联网层对应网络层;设备驱动程序和硬件对应物理层。如下图所示:’

  

  在linux上,四层以下被称为通讯子网,四层以上被称为应用层。前者更注重通信细节,主要实现主机与主机之间如何完成数据报文传输;后者更注重应用层细节,主要实现资源交换

  linux启动后,应用层细节在用户空间实现,通信细节则在内核空间实现。

  所以,最原始最有需求的跨主机间的通信,皆由内核完成;相对而言真正的应用则是通信协议在用户空间特定的实现方式,比如dns完成域名解析,比如ssh实现安全登陆。自然,既是完成特定功能,便不应该位于内核空间。

  当然,也有所疑惑,主机间的通信不是通过IP地址间进行通信的吗? 没错。但是Ip协议本身并不可靠,且是无连接的。相对而言,tcp协议确是有链接,传输层在一定程度上弥补了网络层的缺陷,当然这仅是其中一部分缘由。 

 


 

二、正题

  回归正题,所谓传输层(tcp、udp)是提供进程地址空间,用端口号(port number)来标识进程地址空间。

  其中tcp是一种传输控制协议,即面向对象协议;通信前需建立虚拟链路,需事先知道对方是否在线,通信结束后还需断开链路(tcp的三次握手)。

  而udp(User Datagram Protocol)是无连接协议;通信前无需建立虚拟链路,无需确定对方是否在线。

  二者为完全不同的协议,且各有0-65535个端口【自然需要排除一些众所周知的端口,80/tcp(http),22/tcp(ssh)等端口】。

  前文所述,所有的应用层协议都位于应用层,倘若需要跨主机间进行通信,必须向内核申请,然而。。。然而,内核标记各主机之间通过网络进行通信时,却是通过套接字方式进行的。

  那么问题又来了,套接字又是什么?

  套接字(Socket):IPC的一种实现方式;主要目的是允许不同主机(也可以是同意主机)上不同进程之间进行通信从而完成数据交换。诚然,套接字既由内核实现也就属于内核,属于system call。事实上,Socket一般称之为Socket API,主要是它在system call中提供了太底层太基础,因此,在C标准库中才被称作Socket API。

  诚然,跨主机间的套接字为:Ip+端口【ip用来标记主机,端口用来标识进程空间】

  所以具体实现方式是:当用户发起跨主机间通信时,会基于套接字的方式调用套接字,从而内核空间申请tcp、udp端口,从而建立虚拟链路(如果是tcp的话)进行通信。

  

  题外话:除了tcp、udp之外还有另一种方式,使用裸套接字的方式,直接封装ip报文。

      Socket的三种类型:

       SOCK_STREAM:tcp套接字

       SOCK_DGRAM:udp套接字

       SOCK_RAM:裸套接字

  综上所述,无论什么网络服务,都必定需要使用网络通信的基本功能。即tcp、udp、或者其他。

 


 

三、深入

  向前一步!

  主机间通过套接字进行通信,套接字为ip+端口,那么问题又来了,如果服务器与客户端进行通信,所使用的套接字又该如何解决?

  端口号(port number)是用来标记进程空间地址(tcp和udp各一种),显然端口号是唯一且独占的。倘若服务器端和客户端皆使用同一端口【80/tcp(http)】,那事情就大条了,服务器端口被独占又如何能够回应多个客户端,显然这是不可能的。所以,只能在妥协中前行,客户端使用随机端口,而服务器端使用固定端口。

 这之中又牵扯出了两大疑问:

 (1)为何是客户端使用随机端口,而不是服务器端?

  服务器端就好比是学院,而客户端好比学院的家。学院的地址必定是固定的,否则又如何上学;相对的,学院的家并无需固定地址。当发起跨主机间通信时,会向内核申请一个随机端口1访问远端服务器

 (2)服务器端是如何回应多个客户端?

  如图:本地发送缓冲对应远端接受缓冲;本地接受缓冲对应远端发送缓冲。在信道通信上是采取不同通信信道(接收和发送不是一个信道),而其中还包含缓冲,抑制高发低收压垮通信信道显然,服务器端一旦接受连接后,响应客户端也是随机端口

  

        

  

 

 另外:事实上,所说套接字是ip+端口并不是完全准确,根据其所使用的地址可划分为多个

     AF_INET:IPv4

     AF_INET::IPv6

     AF_UNIX:同一主机不同进程中的通信时使用

 且每种类型至少都提供了两种套接字(Socket),一种是无连接,有边界的,不可靠传递的数据报(UDP);另一种是有连接,有边界,可靠传递的流(TCP)。顺便一提,AF_UNIX不同于另外两种,它无需经过数据链路层,仅仅在传输层(第三层)中便可完成通信。

 


随机端口:

 IANA将端口范围进行了明确划分:

  0-1023:永久划分给应用程序使用的端口,特权端口(同样也是管理员才能使用的端口范围),比如:22/tcp(ssh)、80/tcp(http)

  1024-41952:注册端口,但是并不严格,分配给某些注册的应用程序使用,比如:3306/tcp(mysql)

  41952+:客户端动态分配的端口,动态端口,或私有端口

 所以,服务器响应客户端的随机端口号事实上是41952号端口以上的动态端口。但是。。。但是,服务器在某些高并发的情况下动态端口的数量是不足的,需手动调整端口范围让其包含41952以下的端口,在linux上修改:/proc/sys/net/ipv4/ip_local_port_range

 不过,调整的端口范围不能包含1024以下的端口,毕竟0-1023只有管理员才能够使用。

   

            

转载于:https://www.cnblogs.com/Forestes/p/7784956.html

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

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

相关文章

linux查看进程运行日志文件,【Linux】常用指令、ps查看进程、kill杀进程、启动停止tomcat命令、查看日志、查看端口、find查找文件...

1.说出 10 个 linux 常用的指令1) ls 查看目录中的文件2)cd /home 进入 / home 目录;cd .. 返回上一级目录;cd ../.. 返回上两级目录3)mkdir dir1 创建一个叫做 dir1 的目录4)rmdir dir1 删除一个叫做 dir1 的目录 (只能删除空目录)5)rm -f file1 删除一…

Java PDF库

最近,我有一项任务是选择一些Java PDF库用于PDF生成。 但这不是一个简单的任务。 我想到的第一件事是iText。 众所周知Java库具有良好的声誉。 但是...有一些塞子。 iText 5版是在AGPL许可下发布的。 即,如果我们想在商业产品中使用iText,则必…

前端工程师必备的几个实用网站

一、配色类网站 http://colorhunt.co 这个网站给我们提供了很多的配色方案,我们直接使用就OK了。使用方法也很简单,鼠标移动到对应的颜色上,我们就可以看到颜色的十六进制码,复制这个颜色到工具里就可以使用了。 https://webgra…

linux 修改jmeter内存溢出,jmeter本机内存溢出如何修改?

websocket连接过程中内存溢出,本机配置的内存最大和最小设置的512;一、后台返回二、结果树返回:Thread Name: 线程组 1-9Sample Start: 2017-09-11 13:59:49 CSTLoad time: 9006Connect Time: 0Latency: 0Size in bytes: 0Sent bytes:0Header…

JSF:在传统组件和时尚性能杀手之间进行选择

这篇博客文章起源于一个大型Web应用程序中的性能问题。 每个人都优化Java代码,但似乎没有人尝试优化JavaScript代码。 奇怪,因为在客户端有很多改进的空间。 我会说,甚至比服务器端还要多。 我们将分析可编辑的JSF标准组件(有时称…

JS之 if语句函数 对接事件动作 函数更改css css对接需要换妆的区id或class

if 函数的实现步骤: function 名字() 指定id , 指定开关(display: none or block) if else 构成逻辑 控制开关 决定在哪里安置一个灯泡, 指定一个id给某个标签 把开关用电线连着灯泡, 安装开关 # id名称{ 属性1 赋值, 属性 2 赋值 , 属性3 赋值 } 所有的赋值都可以成为一…

小型Hadoop集群的Ganglia配置和一些故障排除

Ganglia是一个针对大型集群的开源,可扩展且分布式的监视系统。 它收集,汇总并提供数十种与计算机相关的指标(例如CPU,内存,存储,网络使用情况)的时序视图。 您可以在UC Berkeley Grid上看到Gang…

margin赋值为负值的几种效果(负值像素,负值百分数)

1、margin-top为负值像素 margin-top为负值像素&#xff0c;偏移值相对于自身&#xff0c;其后元素受影响&#xff0c;见如下代码&#xff1a; 1 <!DOCTYPE html>2 <html lang"zh">3 <head>4 <meta charset"UTF-8" />5 &…

File如何转换成MultipartFile

MutipartFile是spring里面定义的接口&#xff0c;它封装了用户在上传图片时所包含的所有信息&#xff0c;但是有些时候我们要将file转换成MutipartFile&#xff0c;才能在保持原有代码逻辑的情况下方便代码的调整&#xff0c;但是file不能直接转换成MutipartFile&#xff0c;现…

Vue 进阶教程之:详解 v-model

分享 Vue 官网教程上关于 v-model 的讲解不是十分的详细&#xff0c;写这篇文章的目的就是详细的剖析一下&#xff0c; 并介绍 Vue 2.2 v-model改进的地方&#xff0c;然后穿插的再说点 Vue 的小知识。在 Vue 中&#xff0c;有许多方法和 Angular 相似&#xff0c;这主要是因…

linux 无密码登录另一台服务器,ECS Linux服务器ssh免密码登录另外一台服务器的具体设置...

若有多台linux服务器&#xff0c;为方便起见&#xff0c;服务器之前可设置免密码ssh登录&#xff0c;具体操作参考如下所示&#xff1a;1 、登录其中一个服务器&#xff0c;执行ssh-keygen -t rsa&#xff0c;按3次回车&#xff0c;将会生成公钥和私钥文件id_rsa和id_rsa.pub&a…

Spring 3.2 @ControllerAdvice批注的异常处理

不久前&#xff0c;我写了一个博客&#xff0c;概述了如何将Spring示例代码升级到3.2版&#xff0c;并演示了其中的一些小“陷阱”。 从那以后&#xff0c;我一直在仔细阅读Spring 3.2的新功能列表&#xff0c;尽管它不包含任何革命性的新更改&#xff0c;但我怀疑Spring的家伙…

DOM元素属性值如果设置为对象

结论&#xff1a;内部会调用toString方法&#xff0c;将设置的对象转换为字符串添加给相应的属性&#xff1b; 这个问题呢&#xff0c;是通过jQuery的each方法中&#xff0c;回调函数的this指向问题而来&#xff1b; 我们知道&#xff0c;回调函数中的this如果指向的是基本数据…

纯CSS3美化单选按钮radio

这种纯CSS3美化单选按钮radio的方法适用于以下情况&#xff1a; 1、可兼容IE9以上&#xff0c;需要兼容IE8的要写IE的hack把样式去掉 2、只支持单选按钮radio&#xff0c;因为单选按钮选中样式的圆圈可以用CSS做出来&#xff0c;但是复选按钮checkbox的选中效果对勾就需要图片…

【洛谷】【二分答案+最短路】P1462 通往奥格瑞玛的道路

在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士&#xff0c;他是部落的中坚力量有一天他醒来后发现自己居然到了联盟的主城暴风城在被众多联盟的士兵攻击后&#xff0c;他决定逃回自己的家乡奥格瑞玛 题目背景【题目描述&#xff1a;】 在艾泽拉斯&#xff0c;有n个城市。编号为1…

训练残骸模式– Java 8中的改进实现

Venkat Subramaniam在今天的演讲中提到了有关“级联方法”模式或“火车残骸”模式的内容&#xff0c;如下所示&#xff1a; >someObject.method1().method2().method3().finalResult()很少有人会将此与构建器模式相关联&#xff0c;但事实并非如此。 无论如何&#xff0c;让…

px、em、pt之间的区别与互相转换

关于px、pt和em的区别&#xff0c;自己有时候也会纠结到底该用什么单位&#xff0c;今天特意查了一些文章&#xff0c;下面这篇虽然很久远了&#xff0c;但解释的比较全面&#xff0c;转载收藏之。点击查看原文&#xff08;原网址已失效&#xff0c;这是其他站点&#xff09; …

3.Apache ZooKeeper数据模型

1. ZooKeeper自下向上的服务视图 Apache ZooKeeper是分布式应用程序的协调服务。 它旨在解决分布式应用程序中与组件协调相关的棘手问题。 它通过暴露一个简单而强大的接口来实现这一点。 应用程序可以设计在通过ZooKeeper API实现的这些接口上&#xff0c;以解决分布式同步&am…

STS插件_ springsource-tool-suite插件各个历史版本

目前spring官网(http://spring.io/tools/sts/all)上可下载的spring插件只有&#xff1a;springsource-tool-suite-3.8.4(sts-3.8.4)。但这只针对指定的eclipse版本适用。 原贴更精彩&#xff1a;http://blog.csdn.net/u010203767/article/details/69211072 sts-3.8.3的下载地址…

idea运行项目时报Error:java无效的源发行版:1.8

如果你安装的是JDK1.7&#xff0c;而在file->project structure中设置的是language level是8的话&#xff0c;就会出现这个错误提示&#xff1a;无效的源发行版&#xff1a;8。 解决办法&#xff1a;将语言级别改为7&#xff0c;或6。即语言级别不能高于你安装的版本。 另外…