关于 socket 的一些问题

2021-11-22 09:00:20 +08:00
 liu1996

最近在学习计算机网络,看到 socket 时产生了一个问题。socket 是 tcp/udp 等的一个抽象接口,那么是不是几乎所有使用 tcp/udp 来建立连接的都需要通过 socket 来调用 tcp/udp ?比如 http 协议等。 网络传输的报文是在传输层来寻找对应端口号,这个是不是就是通过 socket 来完成的? socket 在客户端与服务端建立连接时会生成一个新的 socket ,在客户端或者服务端调用 close 方法时断开这个连接,那么 http 协议每次请求是不是都会创建一个 socket?在服务端响应完毕后关闭这个 socket 连接?

3573 次点击
所在节点    程序员
21 条回复
mangoDB
2021-11-22 09:09:13 +08:00
如果使用 Python 的话,可以自己编写一段通过 Requests 库发起 HTTP 请求的代码,然后在 Debug 模式下一步一步的走下去,你就能找到答案。
mazyi
2021-11-22 09:11:23 +08:00
你是问 http 还是问 socket 还是问所有的应用层协议,你需要搞清楚
aladdinding
2021-11-22 09:25:07 +08:00
http 有 keep-alive ,可以多个请求走一个连接
LLaMA2
2021-11-22 09:48:05 +08:00
tcp/udp 是协议,是概念上是学术上的一套称呼,他提供了一整套方法论。
socket 是给你一种实现,也就是程序,库,完整的实现。
你构建的程序无非是使用 socket 库,如果你懂硬件,手里有网卡驱动,或者干脆网卡都是你自己生产的,且符合标准,那你完全可以自己在驱动层自己完成网络交互,网卡无非就是把数据变成一种信号,对端再把这个信号解码成数据而已嘛!
BigMountain
2021-11-22 09:55:12 +08:00
你就理解 socket 是 tcp/udp 协议的抽象就行了 它工作在 tcp/udp 协议这层。
其他的例如 http resp 等等协议都是基于 tcp 协议。 如果你需要实现一个 http 协议( http 基于 tcp ) 那么就通过 socket 进行编解码转换来实现 http 。
sujin190
2021-11-22 10:09:36 +08:00
你想的是对的,这就是分层抽象的逻辑
misaka19000
2021-11-22 10:10:36 +08:00
额。。。多看书吧

《 HTTP 权威指南》、《 Unix 环境高级编程》、《 Unix 网络编程》
lesismal
2021-11-22 10:11:21 +08:00
楼主需要:《图解 tcp/ip 》+《 tcp/ip 详解》+ wireshark
1. 入门阶段,如果不看图解这本、直接啃详解或者其他数很吃力要花费很久;
2. 没有详解这本,图解又太简单了,了解不到深入细致;
3. 没有 wireshark ,看再多也难记得住,实践出真知。另外 tcp 是大头,把 tcp 11 种状态转换图放在桌面上,配合抓包看 tcp 各种流程,tcp 搞熟悉了其他的多看看就容易得多了
cweijan
2021-11-22 10:35:35 +08:00
楼上的扔一堆书好像有点毛病, 楼主已经理解的差不多了, 有两个误区
1. Socket 是由操作系统实现的, 所以说是由操作操作寻找端口比较合理
2. 不是每个 HTTP 请求都会创建一个新的 Socket(即 TCP 连接), 例如浏览器对 HTTP 实现了 Keep-Alive 机制, 间隔时长较短的 HTTP 请求会复用 TCP 连接, 不会重新创建
CRVV
2021-11-22 10:45:22 +08:00
socket 指的是 https://en.wikipedia.org/wiki/Berkeley_sockets
它是一个接口( API, interface )而不是实现( implementation )。

> 是不是几乎所有使用 tcp/udp 来建立连接的都需要通过 socket 来调用 tcp/udp ?
TCP/UDP 也可以用其它的接口,比如 https://www.nongnu.org/lwip/2_0_x/raw_api.html
但是在通常的操作系统上( Windows/Linux/BSD/macOS )用的接口都是 socket

> 网络传输的报文是在传输层来寻找对应端口号,这个是不是就是通过 socket 来完成的?
端口号这些属于网络协议的实现,和接口没关系。

其它和 HTTP 相关的问题,那是 HTTP 协议的实现,和 socket 更没关系了。
ysc3839
2021-11-22 11:34:08 +08:00
是。如果你指的 socket 是 socket API ,不是。HTTP/1.x 没有开启 Keep-Alive 的情况下,是。是。
liu1996
2021-11-22 11:38:02 +08:00
@cweijan 感谢回复。
liu1996
2021-11-22 11:40:49 +08:00
@CRVV 感谢回复。我上面的关于 http 的问法不对,其实我想表达的是 http 请求建立 tcp 连接的话需要 3 次握手,这个是不是通过 socket 来实现的
liu1996
2021-11-22 11:41:14 +08:00
@BigMountain 感谢回复
unixeno
2021-11-22 12:34:42 +08:00
@liu1996 是,也不是,要看你说的 socket 具体指代的啥。TCP 握手是操作系统帮你处理的。
对于客户端来说,你 connect 时就会进行握手,完成之后才会返回你 fd 。
对于服务端,你 accept 的时候系统会帮你处理握手
advancejar
2021-11-22 13:28:54 +08:00
@liu1996 学个 django 开头的来说说,python 就是用 socket 来实现 http 的
ohwind
2021-11-22 14:45:29 +08:00
TCP/IP 是协议,而 Socket 是抽象出来的接口(API),一般系统的 socket 函数、Socket 类则是接口的实现。
git00ll
2021-11-22 18:39:33 +08:00
楼主,java 里面,apache httpclient 发送 http 请求,就是通过创建 java 里面的 socket ,将报文发送过去的。
只不过用完后 socket 连接会放到池里复用。

ungrown
2021-11-23 10:13:23 +08:00
一个基础概念的问题,炸出来一堆平时只顾干活却从来没把基本原理整明白的水货
ungrown
2021-11-23 10:45:57 +08:00
@CRVV #10
咱非得这么咬文嚼字吗?就算要嚼,就不能先放宽对语义的要求,把关联性讲完了,再补充说明“问题中各概念间的不对等性”吗?

套接字是接口,HTTP 是协议,这俩是两个“象限”的东西没错,但真就一句“更没关系了”这也太不负责任了。
HTTP 算是应用层协议,TCP 是位于更底层的传输层协议。实现 TCP 的库提供了套接字的调用接口,实现 HTTP 的库大多数也依赖于这些接口。楼主想问的不就是这方面的信息吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/817019

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX