HTTP协议的底层实际上是由TCP协议和IP协议(简称TCP/IP)构成的。传输控制协议TCP的作用是保证数据的完整性和可靠性,防止丢包。常见问题:TCP和UDP有什么区别回答:TCP可靠,面向
HTTP协议的底层实际上是由TCP协议和IP协议(简称TCP/IP)构成的。
传输控制协议TCP的作用是保证数据的完整性和可靠性,防止丢包。
常见问题:
TCP和UDP有什么区别
回答:TCP可靠,面向连接,比UDP慢;UDP不可靠,面向连接,比TCP快。完成了。
什么是TCP的三次握手
答:在每个连接建立之前,客户端和服务器必须进行三次对话,然后才能正式传输内容。三段对话大概是这样的:
1. 客户端:我要连接你了,可以吗
2. 服务端:嗯,我准备好了,连接我吧
3. 客户端:那我连接你咯。
4. 开始后面步骤
上面内容足以应付前端面试中关于 TCP 的考题
如果想了解更多关于TCP的知识,可以买《TCP/IP详解》(第一册)(一共三册,先买一册就好)。
不过还是那句话,这不是前端内容,以后的课程我也不会和TCP扯上关系。你只需要了解一点TCP。
IP协议(英语:互联网协议)只要你在互联网,那么你就会有一个IP。一般来说,IP分为“内网IP”和“外网IP”
你买电信的带宽,一年1000多。电信为您提供DNS服务。你买了一个路由器,然后把电脑和手机连接到路由器广播的无线WIFI上。只要路由器连接到电信服务器,路由器就会有一个“外网IP”。例如,“14.17.32.211”是一个外网IP。这是你在网上的地址。但是如果你重启路由器,很有可能你会被重新分配一个“外部IP”,也就是说你的路由器没有“固定外部IP”你可以每年花几千块租一个“固定外部IP”,但显然不会这么浪费钱。像腾讯、阿里这样的大公司租用了很多外网IP,这样就可以给我们提供稳定的服务。但是有一个问题。如果你路由器外网的IP是14.17.32.211,那你手机和电脑的IP是什么?答案是“内网IP”。路由器将在您的家中创建一个内部网。内部网中的设备使用内部网IP。一般来说,这个IP的格式是192.168.xxx.xxx一般来说,路由器会给自己分配一个容易记忆的内网IP,比如192.168.1.1,然后路由器会给内网的每个设备分配一个不同的内网IP,比如电脑是192.168.1.2,手机是192.168.1.3,等等。
现在路由器有两个IP,一个外部IP(14.17.32.211)和一个内部IP(192.168.1.1)。内网的设备可以互相访问(比如用电脑或手机访问http://192.168.1.1可以检查你的路由器),但是不能直接
外网的设备可以互相访问(比如qq.com可以把主页发送到你的路由器,你的路由器有一个外网IP),但是外网的设备不能访问你的内网设备(很好理解,内网是一个封闭的网络,外人进不去,所以实际上qq.com不能直接把主页发送到你的电脑和手机上)。
问题来了,那qq.com是怎么把首页发到我手机上的?
答案是通过路由器中转。
路由器收到来自qq.com的页面后,将其发送到您的计算机或手机。路由器知道如何给这些信息指路,路由器是引路人,这就是“路线”这个词的由来。路是“必经之路”中的路。“因”是“必经之路”中的“因”(意为“因”)。所有的信息都必须通过路由器,然后被引导到它应该去的地方。
也就是说,内网和外网就像两个隔离的空房间,无法互通。唯一的连接点就是路由器(因为路由器既有外网IP又有内网IP),所以路由器有时也叫网关。这是一个门户,一个人守着它,一万个人也无法打开它。如果路由器和电信之间的连接中断,内部网中的所有设备都将无法访问互联网。(这个很好理解,相当于唯一的出路被打破了)
除了内网 IP 和外网 IP,还有两个特别特殊的 IP,就是本地 IP:127.0.0.1。本地 IP 永远表示设备自己。不信你可以 ping 127.0.0.1 一下,会发现只需要 0.01 ms 就得到了响应(你 ping qq.com 需要几十毫秒才得到响应)
默认情况下,hosts文件中会有一行127.0.0.1 localhost,表示localhost指向127.0.0.1,所以localhost也表示设备本身。不信你试试ping localhost你会发现你其实是ping 127.0.0.1。
还有一个特别特殊的 IP:0.0.0.0,它不表示任何设备。这个 IP 不同的地方含义不同,以后我们会用到,用到的时候再说意思。
港口您想要访问设备(前提是您使用TCP或UDP协议。记住,HTTP使用TCP),指定IP是不够的,还必须指定端口。
端口其实是一个数字,而不是一种硬件
。
服务器(硬件)不必只提供一种服务。比如一个服务器同时提供HTTP服务、FTP服务和SMTP服务(邮件服务),那么只有一个IP无法告诉服务器你想用哪个服务。
所以这里有一个重要的原则:
一个端口对应一个服务。
例如
要提供 HTTP 服务你最好使用 80 端口(能不能使用别的端口?可以,不过不建议你违反约定)要提供 HTTPS 服务你最好使用 443 端口(能不能使用别的端口?可以,不过不建议你违反约定)要提供 FTP 服务你最好使用 21 端口(能不能使用别的端口?可以,不过不建议你违反约定)
问题1:我如何知道我应该使用哪个端口?
维基百科已经告诉你0到1023端口对应的所有服务。点进去看看。
问题二:有几个端口?
每台机器总共有65,535 (2的16次方减1)个端口(这是协议中规定的)。但是,这些端口的使用受到一些规则的管制。
0 到 1023(2的10次方减1)号端口是留给系统使用的,你只有拥有了管理员权限后,才能使用这 1024 个端口。其他端口可以给普通用户使用如果一个端口正在提供服务,也就是被占用了,那么就不能再使用这个端口。除非你先停掉正在占用这个端口的服务。以后你们会经常遇到这个问题。