`
charlotte
  • 浏览: 121778 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

端口sockettcpip

 
阅读更多

疑惑一个问题 tco/ip和socket到底是什么关系?为什么多个socket client可以绑定一个端口?

 

(下面是网上找,暂时凑活理解把)

要写网络程序就必须用Socket,这是程序员 都知道的。而且,面试的时候,我们也会问对方会不会Socket编程?一般来说,很多人都会说,Socket编程基本就是listen,accept以及send,write等几个基本的操作。是的,就跟常见的文件操作一样,只要写过就一定知道。

对于网络编程 ,我们也言必称TCP/IP,似乎其它网络协议 已经不存在了。对于TCP/IP,我们还知道TCP和UDP,前者可以保证数据的正确和可靠性 ,后者则允许数据丢失 。最后,我们还知道,在建立连接前,必须知道对方的IP地址和端口号 。除此,普通的程序员就不会知道太多了,很多时候这些知识已经够用了。最多,写服务程序的时候,会使用多线程 来处理并发访问。

我们还知道如下几个事实:

1。一个指定的端口号不能被多个程序共用。比如,如果IIS占用了80端口 ,那么Apache就不能也用80端口了。

2。很多防火墙 只允许特定目标端口的数据包通过。

3。服务程序在listen某个端口并accept某个连接请求后,会生成一个新的socket来对该请求进行处理。

于 是,一个困惑了我很久的问题就产生了。如果一个socket创建后并与80端口绑定后,是否就意味着该socket占用了80端口呢?如果是这样的,那么 当其accept一个请求后,生成的新的socket到底使用的是什么端口呢(我一直以为系统会默认给其分配一个空闲的端口号)?如果是一个空闲的端口, 那一定不是80端口了,于是以后的TCP数据包的目标端口就不是80了--防火墙一定会组织其通过的!实际上,我们可以看到,防火墙并没有阻止这样的连 接,而且这是最常见的连接请求和处理方式。我的不解就是,为什么防火墙没有阻止这样的连接?它是如何判定那条连接是因为connet80端口而生成的?是 不是TCP数据包里有什么特别的标志?或者防火墙记住了什么东西?

后来,我又仔细研读了TCP/IP的协议栈 的原理,对很多概念有了更深刻的认识。比如,在TCP和UDP同属于传输层,共同架设在IP层(网络层)之上。而IP层主要负责的是在节点之间(End to End)的数据包传送,这里的节点是一台网络设备 ,比如计算机 。 因为IP层只负责把数据送到节点,而不能区分上面的不同应用,所以TCP和UDP协议在其基础上加入了端口的信息,端口于是标识的是一个节点上的一个应 用。除了增加端口信息,UPD协议基本就没有对IP层的数据进行任何的处理了。而TCP协议还加入了更加复杂的传输控制,比如滑动的数据发送窗口 (Slice Window),以及接收确认和重发机制,以达到数据的可靠传送。不管应用层 看到的是怎样一个稳定的TCP数据流 ,下面传送的都是一个个的IP数据包,需要由TCP协议来进行数据重组。

所以,我有理由怀疑,防火墙并没有足够的信息判断TCP数据包的更多信息,除了IP地址和端口号。而且,我们也看到,所谓的端口,是为了区分不同的应用的,以在不同的IP包来到的时候能够正确转发。

TCP/IP只是一个协议栈,就像操作系统运行机制 一样,必须要具体实现,同时还要提供对外的操作接口。就像操作系统会提供标准的编程接口,比如Win32编程接口一样,TCP/IP也必须对外提供编程接口,这就是Socket编程接口--原来是这么回事啊!

在Socket编程接口里,设计者提出了一个很重要的概念,那就是socket。这个socket跟文件句柄 很相似,实际上在BSD系统里就是跟文件句柄 一样存放在一样的进程句柄表里。这个socket其实是一个序号,表示其在句柄表中的位置。这一点,我们已经见过很多了,比如文件句柄,窗口句柄 等等。这些句柄,其实是代表了系统中的某些特定的对象,用于在各种函数中作为参数传入,以对特定的对象进行操作--这其实是C语言的问题,在C++语言里,这个句柄其实就是this指针 ,实际就是对象指针啦。

现 在我们知道,socket跟TCP/IP并没有必然的联系。Socket编程接口在设计的时候,就希望也能适应其他的网络协议。所以,socket的出现 只是可以更方便的使用TCP/IP协议栈而已,其对TCP/IP进行了抽象,形成了几个最基本的函数接口。比如 create,listen,accept,connect,read和write等等。

现在我们明白,如果一个程序创建了 一个socket,并让其监听80端口,其实是向TCP/IP协议栈声明了其对80端口的占有。以后,所有目标是80端口的TCP数据包都会转发给该程序 (这里的程序,因为使用的是Socket编程接口,所以首先由Socket层来处理)。所谓accept函数,其实抽象的是TCP的连接建立过程。 accept函数返回的新socket其实指代的是本次创建的连接,而一个连接是包括两部分信息的,一个是源IP和源 端 口,另一个是宿IP和宿端口。所以,accept可以产生多个不同的socket,而这些socket里包含的宿IP和宿端口是不变的,变化的只是源IP 和源端口。这样的话,这些socket宿端口就可以都是80,而Socket层还是能根据源/宿对来准确地分辨出IP包和socket的归属关系,从而完 成对TCP/IP协议的操作封装!而同时,放火墙的对IP包的处理规则也是清晰明了,不存在前面设想的种种复杂的情形。

明白socket只是对TCP/IP协议栈操作的抽象,而不是简单的映射关系,这很重要!

分享到:
评论

相关推荐

    计算机三大端口:公认端口、注册端口、动态和私有端口

    计算机端口可分为3大类: 1) 公认端口(Well Known Ports):从0到1023,它们紧密绑定于一些服务。通常这些端口的通讯明确表明了某种服 务的协议。例如:80端口实际上总是HTTP通讯。  2) 注册端口(Registered Ports):...

    端口大全.pdf 端口大全.pdf 端口大全.pdf

    端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全.pdf端口大全...

    路由器如何禁用端口-路由器过滤端口的方法.docx

    路由器如何禁用端口-路由器过滤端口的方法全文共9页,当前为第1页。路由器如何禁用端口-路由器过滤端口的方法全文共9页,当前为第1页。路由器如何禁用端口,路由器过滤端口的方法 路由器如何禁用端口-路由器过滤端口...

    扫描IP开放端口

    扫描IP开放端口,支持多线程扫描。 通过该工具可以扫描常用的端口和指定的端口是否开放。 常用端口号: 代理服务器常用以下端口: (1). HTTP协议代理服务器常用端口号:80/8080/3128/8081/9080 (2). SOCKS...

    高通机型 无需root开启diag端口 开启基带端口 写基带qcn 读写参数

    用于一些高通机型开启diag端口的工具 在机型中安装资源内的apk。用于激活手机diag端口参数。然后链接电脑手机按步骤开启端口即可开启、 用于高通芯片。 无法常规打开diag端口的可以使用。 资源用于没有root 无法常规...

    TCP端口监听示例TCP端口监听示例

    TCP端口监听示例 TCP端口监听示例 TCP端口监听示例 TCP端口监听示例 TCP端口监听示例 TCP端口监听示例 TCP端口监听示例 TCP端口监听示例

    计算机网络课程设计 多线程端口扫描器(TCP/UDP端口扫描)(java实现)带GUI界面

    2.2端口的有效范围是1~65535,在该范围内使用多线程机制循环创建客户端套接字对象,对某一地址(段)的主机端口进行扫描,若套接字没有发生异常,说明该端口打开并提供服务,返回该开放端口的类型(如UDP端口还是TCP...

    端口镜像与端口映射

    端口镜像是将指定端口(源端口)、VLAN(源VLAN)或CPU(源CPU)的报文复制一份到其它端口(目的端口),目的端口会与数据监测设备相连,用户利用这些数据监测设备来分析复制到目的端口的报文,进行网络监控和故障...

    端口详解 端口详解 端口详解

    端口详解 端口详解 端口详解 端口详解 端口详解

    异速联路由器端口映射.docx

    异速联路由器端口映射全文共2页,当前为第1页。异速联路由器端口映射全文共2页,当前为第1页。实施异速联方法 上金万维官网下载异速联 安装异速联服务器 账户配置一下,然后设置用户,发布程序 然后做路由器端口映射...

    haproxy实现80 mstsc ssh 端口复用

    有没有想过把22端口 3389端口 80端口一次性绑在一个端口上 在对外端口非常紧缺的时候,这种做法非常重要 haproxy是一个传统的负载均衡软件,但是他可以实现通过协议判断来实现数据包转发的功能 比如80端口 http的...

    c++端口转发工具,c++端口转发工具

    c++端口转发工具,vs2010编写,可以实现自定义端口转发至另一个自定义端口。 c++端口转发工具,vs2010编写,可以实现自定义端口转发至另一个自定义端口。

    自动添加端口转发工具,自动添加端口映射工具

    爱好使用动态域名的朋友可能常常被设置端口转发权限而苦恼,本工具可以让你非常方便的添加端口映射。 操作方法:假如你的网页提供服务的端口是80,那么将上下两个端口映射端口都填上80,再点击执行动作即可添加完成。...

    网络端口及其详解(SNMP等)

    (1)公认端口(Well Known Ports):从0到1023,它们紧密绑定(binding)于一些服务。通常这些端口的通讯明确表明了某种服务的协议。例如:80端口实际上总是HTTP通讯。 (2)注册端口(Registered Ports):从1024...

    c#向指定端口发送数据,监听指定端口

    c#向指定端口发送数据,监听指定端口,使用端口监听获取数据信息,向指定端口发送需要的数据

    实验4:双端口存储器实验 ----独立方式.pdf

    实验4:双端口存储器实验 ----独立方式.pdf实验4:双端口存储器实验 ----独立方式.pdf实验4:双端口存储器实验 ----独立方式.pdf实验4:双端口存储器实验 ----独立方式.pdf实验4:双端口存储器实验 ----独立方式.pdf...

    瑞友天翼更改5872端口和80端口

    更改瑞友天翼服务器端的5872端口和80端口

    端口扫描器的设计与实现

    本文档包含端口扫描器课程设计全套代码(Java实现),课程设计报告,以及说明文档。内容齐全,代码可以运行,有质量保证。 课程设计报告包含五大模块:1.有关端口扫描的基本知识。 2.端口扫描的基本原理。 3.基于...

    端口转发-c++一个不错的参考

    Dos下的软件大家应该会用吧,x:lcx –listen 34 2389,说明一下这句指令的意思,这句话的意思就是监听本机的34端口然后将数据转发到2389端口,当然这里的34 2389端口是看我心情而定,但是呢,必须要注意这些端口也不...

    端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan

    端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口扫描x-scan端口...

Global site tag (gtag.js) - Google Analytics