不是吧阿sir,你这计算机网络也太熟了,震惊面试官一整年

​ 最常见的可选字段是最长报文大小,又称为 MSS (Maximum Segment Size)。每个连接方通常都在通信的第一个报文段(为建立连接而设置 S Y N标志的那个段)中指明这个选项。它指明本端所能接收的最大长度的报文段。

​ UDP报文格式:

在这里插入图片描述

白嫖资料

​ 端口号:

​ 用来表示发送和接受进程。由于 I P层已经把I P数据报分配给T C P或U D P(根据I P首部中协议字段值),因此T C P端口号由T C P来查看,而 U D P端口号由UDP来查看。T C P端口号与UDP端口号是相互独立的。

​ 长度:

​ UDP长度字段指的是UDP首部和UDP数据的字节长度。该字段的最小值为 8字节(发送一份0字节的UDP数据报是 O K)。

​ 检验和:

​ UDP检验和是一个端到端的检验和。它由发送端计算,然后由接收端验证。其目的是为了发现UDP首部和数据在发送端到接收端之间发生的任何改动。

​ **IP报文格式:**普通的IP首部长为20个字节,除非含有可选项字段。

在这里插入图片描述

白嫖资料

4位版本:

​ 目前协议版本号是4,因此IP有时也称作IPV4.

​ 4位首部长度:

​ 首部长度指的是首部占32bit字的数目,包括任何选项。由于它是一个4比特字段,因此首部长度最长为60个字节。

服务类型(TOS):

​ 服务类型字段包括一个3bit的优先权字段(现在已经被忽略),4bit的TOS子字段和1bit未用位必须置0。4bit的TOS分别代表:最小时延,最大吞吐量,最高可靠性和最小费用。4bit中只能置其中1比特。如果所有4bit均为0,那么就意味着是一般服务。

​ 总长度:

​ 总长度字段是指整个IP数据报的长度,以字节为单位。利用首部长度和总长度字段,就可以知道IP数据报中数据内容的起始位置和长度。由于该字段长16bit,所以IP数据报最长可达65535字节。当数据报被分片时,该字段的值也随着变化。

​ 标识字段:

​ 标识字段唯一地标识主机发送的每一份数据报。通常每发送一份报文它的值就会加1。

​ 生存时间:

​ TTL(time-to-live)生存时间字段设置了数据报可以经过的最多路由器数。它指定了数据报的生存时间。TTL的初始值由源主机设置(通常为 3 2或6 4),一旦经过一个处理它的路由器,它的值就减去 1。当该字段的值为 0时,数据报就被丢弃,并发送 ICMP 报文通知源主机。

​ 首部检验和:

​ 首部检验和字段是根据 I P首部计算的检验和码。它不对首部后面的数据进行计算。 ICMP、IGMP、UDP和TCP在它们各自的首部中均含有同时覆盖首部和数据检验和码。

​ 以太网报文格式:

在这里插入图片描述

​ 目的地址和源地址:

白嫖资料

​ 是指网卡的硬件地址(也叫MAC 地址),长度是48 位,是在网卡出厂时固化的。

​ 数据:

​ 以太网帧中的数据长度规定最小46 字节,最大1500 字节,ARP 和RARP 数据包的长度不够46 字节,要在后面补填充位。最大值1500 称为以太网的最大传输单元(MTU),不同的网络类型有不同的MTU,如果一个数据包从以太网路由到拨号链路上,数据包度大于拨号链路的MTU了,则需要对数据包进行分片fragmentation)。ifconfig 命令的输出中也有“MTU:1500”。注意,MTU 个概念指数据帧中有效载荷的最大长度,不包括帧首部的长度。

9、浏览器输入URL并回车的过程以及相关协议,DNS查询过程。

​ **过程:**DNS解析、TCP连接、发送HTTP请求、服务器处理请求并返回HTTP报文、浏览器渲染、结束

| 过程 | 使用的协议 |

| — | — |

| 1、浏览器查找域名DNS的IP地址DNS查找过程(浏览器缓存、路由器缓存、DNS缓存) | DNS:获取域名对应的ip |

| 2、根据ip建立TCP连接 | TCP:与服务器建立连接 |

| 3、浏览器向服务器发送HTTP请求 | HTTP:发送请求 |

| 4、服务器响应HTTP响应 | HTTP |

| 5、浏览器进行渲染 | |

10、HTTP1.0、1.1、2.0之间的区别

​ **HTTP1.0:**默认使用Connection:cloose,浏览器每次请求都需要与服务器建立一个TCP连接,服务器处理完成后立即断开TCP连接(无连接),服务器不跟踪每个客户端也不记录过去的请求(无状态)。

​ **HTTP1.1:**默认使用Connection:keep-alive(长连接),避免了连接建立和释放的开销;通过Content-Length字段来判断当前请求的数据是否已经全部接受。不允许同时存在两个并行的响应。

​ **HTTP2.0:**引入二进制数据帧和流的概念,其中帧对数据进行顺序标识;因为有了序列,服务器可以并行的传输数据。

​ http1.0和http1.1的主要区别如下:​ 1、缓存处理:1.1添加更多的缓存控制策略(如:Entity tag,If-Match)​ 2、网络连接的优化:1.1支持断点续传​ 3、错误状态码的增多:1.1新增了24个错误状态响应码,丰富的错误码更加明确各个状态​ 4、Host头处理:支持Host头域,不在以IP为请求方标志​ 5、长连接:减少了建立和关闭连接的消耗和延迟。

​ http1.1和http2.0的主要区别:​ 1、新的传输格式:2.0使用二进制格式,1.0依然使用基于文本格式​ 2、多路复用:连接共享,不同的request可以使用同一个连接传输(最后根据每个request上的id号组合成 正常的请求)​ 3、header压缩:由于1.X中header带有大量的信息,并且得重复传输,2.0使用encoder来减少需要传输的 hearder大小​ 4、服务端推送:同google的SPDUY(1.0的一种升级)一样

11、HTTP与HTTPS之间的区别,HTTPS链接建立的过程,了解对称加密算法和非对称加密算法不?

​ HTTP与HTTPS之间的区别:

| HTTP | HTTPS |

| — | — |

| 默认端口80 | HTTPS默认使用端口443 |

| 明文传输、数据未加密、安全性差 | 传输过程ssl加密、安全性较好 |

| 响应速度快、消耗资源少 | 响应速度较慢、消耗资源多、需要用到CA证书 |

​ HTTPS链接建立的过程:

​ 1.首先客户端先给服务器发送一个请求

​ 2.服务器发送一个SSL证书给客户端,内容包括:证书的发布机构、有效期、所有者、签名以及公钥

​ 3.客户端对发来的公钥进行真伪校验,校验为真则使用公钥对对称加密算法以及对称密钥进行加密

​ 4.服务器端使用私钥进行解密并使用对称密钥加密确认信息发送给客户端

​ 5.随后客户端和服务端就使用对称密钥进行信息传输

​ 对称加密算法:

​ 双方持有相同的密钥,且加密速度快,典型对称加密算法:DES、AES白嫖资料

非对称加密算法:

​ 密钥成对出现(私钥、公钥),私钥只有自己知道,不在网络中传输;而公钥可以公开。相比对称加密速度较慢,典型的非对称加密算法有:RSA、DSA

12、HTTP请求有哪些。get和Post区别。

HTTP请求:

| 方法 | 描述 |

| — | — |

| GET | 向特定资源发送请求,查询数据,并返回实体 |

| POST | 向指定资源提交数据进行处理请求,可能会导致新的资源建立、已有资源修改 |

| PUT | 向服务器上传新的内容 |

| HEAD | 类似GET请求,返回的响应中没有具体的内容,用于获取报头 |

| DELETE | 请求服务器删除指定标识的资源 |

| OPTIONS | 可以用来向服务器发送请求来测试服务器的功能性 |

| TRACE | 回显服务器收到的请求,用于测试或诊断 |

| CONNECT | HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器 |

get和Post区别:

| | GET | POST |

| — | — | — |

| 可见性 | 数据在URL中对所有人可见 | 数据不会显示在URL中 |

| 安全性 | 与post相比,get的安全性较差,因为所发送的数据是URL的一部分 | 安全,因为参数不会被保存在浏览器历史或web服务器日志中 |

| 数据长度 | 受限制,最长2kb | 无限制 |

| 编码类型 | application/x-www-form-urlencoded | multipart/form-data |

| 缓存 | 能被缓存 | 不能被缓存 |

13、HTTP常见响应状态码,从1xx到5xx

​ 100:Continue — 继续。客户端应继续其请求。

​ 200:OK — 请求成功。一般用于GET与POST请求。

​ 301:Moved Permanently — 永久重定向。

​ 302:Found — 暂时重定向。

​ 400:Bad Request — 客户端请求的语法错误,服务器无法理解。

​ 403:Forbideen — 服务器理解请求客户端的请求,但是拒绝执行此请求。

​ 404:Not Found — 服务器无法根据客户端的请求找到资源(网页)。

​ 500:Internal Server Error — 服务器内部错误,无法完成请求。

​ 502:Bad Gateway — 作为网关或者代理服务器尝试执行请求时,从远程服务器接收到了无效的响应。

14、重定向和转发区别

​ 重定向:redirect:

​ 地址栏发生变化

​ 重定向可以访问其他站点(服务器)的资源

​ 重定向是两次请求。不能使用request对象来共享数据

白嫖资料

转发:forward:

​ 转发地址栏路径不变

​ 转发只能访问当前服务器下的资源

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

写在最后

作为一名即将求职的程序员,面对一个可能跟近些年非常不同的 2019 年,你的就业机会和风口会出现在哪里?在这种新环境下,工作应该选择大厂还是小公司?已有几年工作经验的老兵,又应该如何保持和提升自身竞争力,转被动为主动?

就目前大环境来看,跳槽成功的难度比往年高很多。一个明显的感受:今年的面试,无论一面还是二面,都很考验Java程序员的技术功底。

最近我整理了一份复习用的面试题及面试高频的考点题及技术点梳理成一份“Java经典面试问题(含答案解析).pdf和一份网上搜集的“Java程序员面试笔试真题库.pdf”(实际上比预期多花了不少精力),包含分布式架构、高可扩展、高性能、高并发、Jvm性能调优、Spring,MyBatis,Nginx源码分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多个知识点高级进阶干货!

由于篇幅有限,为了方便大家观看,这里以图片的形式给大家展示部分的目录和答案截图!

Java经典面试问题(含答案解析)

阿里巴巴技术笔试心得

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

Dubbo、Nginx等多个知识点高级进阶干货!**

由于篇幅有限,为了方便大家观看,这里以图片的形式给大家展示部分的目录和答案截图!
[外链图片转存中…(img-W1LaavcC-1712802434013)]

Java经典面试问题(含答案解析)

[外链图片转存中…(img-I3DPGPCJ-1712802434013)]

阿里巴巴技术笔试心得

[外链图片转存中…(img-s4Hdf6sf-1712802434013)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-KoYnQ4K2-1712802434014)]

  • 12
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值