返回顶部
首页 > 资讯 > 精选 >Socket与TCP/IP的关系
  • 190
分享到

Socket与TCP/IP的关系

2023-06-04 21:06:28 190人浏览 安东尼
摘要

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

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

对于网络编程,我们也言必称 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 协议栈操作的抽象,而不是简单的映射关系,这很重要!

一个socket 由四个标识决定,客户端ip,客户端port, 服务端ip,服务端port,

在一个客户端和服务端通信过程中,客户端ip, 服务端ip,服务端port,都是相同的,只有客户端port不同,但是只要一个不同,就算是一个新的socket,

所以accept 返回的是一个新的socket。

--结束END--

本文标题: Socket与TCP/IP的关系

本文链接: https://lsjlt.com/news/239783.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Socket与TCP/IP的关系
    要写网络程序就必须用 Socket ,这是程序员都知道的。而且,面试的时候,我们也会问对方会不会 Socket 编程?一般来说,很多人都会说, Socket 编程基本就是 listen , accept 以及 send , write 等几...
    99+
    2023-06-04
  • PostgreSQL pgsocket: Extension for Simple TCP/IP Socket Client
    背景 PostgreSQL 插件,向外部tpc/ip socket服务发生字节流。 pgsocket is an extension for PostgreSQL server to send b...
    99+
    2024-04-02
  • 一文看懂IP、UDP和TCP三者的关系
    互联网,实际上是一套理念和协议组成的体系架构。其中,协议是一套众所周知的规则和标准,如果各方都同意使用,那么它们之间的通信将变得毫无障碍。互联网,实际上是一套理念和协议组成的体系架构。其中,协议是一套众所周知的规则和标准,如果各方都同意使用...
    99+
    2023-06-03
  • Python socket网络编程TCP/IP服务器与客户端通信
    Python socket网络编程 初学 python,前段时间买了两本书《python 编程从入门到实践》《Python 核心编程第三版》,第一本书主要讲的是一些基本语法和一些基本的使用方法,而第二本则深...
    99+
    2022-06-04
    客户端 网络编程 通信
  • C++ TCP/IP 关于tcp断线重连的问题
    在工控上经常用到tcp连接,比如串口服务器或某些支持modbustcp协议的仪表等,以前尽量使用串口服务器的虚拟串口功能,现在逐步使用上了tcpserver或tcpclient模式。 搜索了个C++ 的tcp断线重连的案例(http://w...
    99+
    2023-09-18
    tcp/ip 网络 服务器 c++
  • MySQL数据库的两种连接方式:TCP/IP和Socket
    Linux平台环境下主要有两种连接方式,一种是TCP/IP连接方式,另一种就是socket连接。 在Windows平台下,有name pipe和share memory(不考虑)两种。 TCP/IP连接是网络中用得最多的一种方式...
    99+
    2017-12-06
    MySQL数据库的两种连接方式:TCP/IP和Socket
  • TCP/IP IP地址概念与应用
    作者简介:一名在校云计算网络运维学生、每天分享网络运维的学习经验、和学习笔记。   座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.什么是IP地址 二.IP地址的组成   三.IP地址分类 ...
    99+
    2023-09-01
    tcp/ip 网络 服务器
  • TCP socket和web socket的区别是什么
    TCP socket和web socket的区别是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。首先我们来阅读这段有166个赞的回答:When you send byt...
    99+
    2023-06-04
  • C++ Socket实现TCP与UDP网络编程
    目录前言TCP1). 服务器2). 客户端3). TCP聊天小项目UDP1). 服务器2). 客户端总结前言 socket编程分为TCP和UDP两个模块,其中TCP是可靠的、安全的,...
    99+
    2024-04-02
  • Nginx中unix socket和tcp socket的区别是什么
    这篇文章主要介绍“Nginx中unix socket和tcp socket的区别是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Nginx中unix socke...
    99+
    2022-12-07
    nginx unix socket tcp socket
  • Java socket通信与C++之间的关系是什么
    Java socket通信与C++之间的关系是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。c++builer与Java socket通信是我们在编程中经常用到的,有不少的...
    99+
    2023-06-17
  • Python基于socket实现TCP/IP客户和服务器通信
    目录前言简单的搭建服务器与客户端服务器客户端create_connection(更简易的客户端)前言 套接字除了用于分析网络地址等功能之外,还可以配置一个服务器,监听到来的消息。 比如你在网络上跟网络机器人聊天,你发...
    99+
    2022-06-02
    Python 客户和服务器通信 Python TCP/IP 通信
  • 详解TCP连接的状态与关闭方式及Winserver系统下的TCP参数优化
    TCP连接的状态:1. CLOSED:表示初始状态,表示没有连接。2. LISTEN:表示服务器在等待连接请求的状态。3. SYN_...
    99+
    2023-09-12
    TCP
  • Java基于TCP协议的Socket通信
    目录简介TCP简介JAVA Socket简介SocketImpl介绍TCP 编程构造ServerSocket1.1 绑定端口1.2 设定客户连接请求队列的长度1.3 设定绑定的IP ...
    99+
    2024-04-02
  • Python基于socket如何实现TCP/IP客户和服务器通信
    这篇文章主要为大家展示了“Python基于socket如何实现TCP/IP客户和服务器通信”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python基于socket如何实现TCP/IP客户和服务...
    99+
    2023-06-15
  • 关于Java单个TCP(Socket)连接发送多个文件的问题
    目录使用一个TCP连接发送多个文件协议的作用定义数据的发送格式(协议)代码客户端服务器端测试结果总结使用一个TCP连接发送多个文件 为什么会有这篇博客? 最近在看一些相关方面的东西,...
    99+
    2023-05-15
    Java单个(Socket)TCP Java TCP发送多个文件
  • 详解从Linux源码看Socket(TCP)的bind
    目录一、一个最简单的Server端例子二、bind系统调用2.1、inet_bind2.2、inet_csk_get_port三、判断端口号是否冲突四、SO_REUSEADDR和SO_REUSEPORT五、SO_RE...
    99+
    2022-06-03
    Linux 源码 Socket bind
  • 怎么解决TCP socket的阻塞问题
    小编给大家分享一下怎么解决TCP socket的阻塞问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!解决TCP socket的阻塞问题大家知道,tcp...
    99+
    2023-06-22
  • 如何进行TCP Socket中的linux实现
    这篇文章给大家介绍如何进行TCP Socket中的linux实现,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。TCP Server端:#include <iostream>#include <cstr...
    99+
    2023-06-16
  • 如何解决TCP socket的阻塞问题
    目录解决TCP socket的阻塞问题在异常处理程序当中退出socket连接TCP连接阻塞的监控和处理我们整理出符合该类异常的特征如下如何查看一个连接的创建时间解决TCP socke...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作